@codecademy/brand 3.24.0-alpha.c07ce0180c.0 → 3.24.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/index.d.ts +0 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/index.js +10 -30
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdown/index.js +20 -36
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/AppHeaderDropdownLink.js +1 -4
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/AppHeaderMenuItem.js +1 -4
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/StyledAppHeaderLink.d.ts +1 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/StyledAppHeaderLink.js +2 -4
- package/dist/AppHeader/AppHeaderElements/AppHeaderLinkSections/index.js +0 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/index.d.ts +0 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/index.js +10 -31
- package/dist/AppHeader/index.d.ts +0 -1
- package/dist/AppHeader/index.js +0 -2
- package/dist/AppHeader/shared/utils.d.ts +1 -2
- package/dist/AppHeader/shared/utils.js +2 -5
- package/dist/AppHeaderMobile/AppHeaderMainMenuMobile/index.d.ts +0 -1
- package/dist/AppHeaderMobile/AppHeaderMainMenuMobile/index.js +11 -18
- package/dist/AppHeaderMobile/AppHeaderSubMenuMobile/index.d.ts +0 -1
- package/dist/AppHeaderMobile/AppHeaderSubMenuMobile/index.js +19 -76
- package/dist/AppHeaderMobile/index.js +10 -38
- package/dist/GlobalFooter/FooterNavLinks/CompanyLinks.d.ts +1 -0
- package/dist/GlobalFooter/FooterNavLinks/CompanyLinks.js +16 -4
- package/dist/GlobalFooter/FooterNavLinks/index.js +5 -3
- package/dist/GlobalFooter/index.d.ts +1 -0
- package/dist/GlobalFooter/index.js +5 -3
- package/dist/GlobalHeader/GlobalHeaderItems.js +12 -1
- package/dist/GlobalHeader/index.d.ts +0 -1
- package/dist/GlobalHeader/index.js +46 -51
- package/dist/GlobalHeader/types.d.ts +0 -1
- package/dist/LayoutMenu/LayoutMenu.js +40 -20
- package/dist/LayoutMenu/LayoutMenuSection.js +5 -0
- package/package.json +1 -1
|
@@ -1,21 +1,20 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
|
-
import { Box,
|
|
2
|
+
import { Box, IconButton, Overlay } from '@codecademy/gamut';
|
|
3
3
|
import { MenuIcon } from '@codecademy/gamut-icons';
|
|
4
|
-
import { Background, css, states, theme
|
|
5
|
-
import {
|
|
4
|
+
import { Background, css, states, theme } from '@codecademy/gamut-styles';
|
|
5
|
+
import { useEffect, useRef, useState } from 'react';
|
|
6
6
|
import * as React from 'react';
|
|
7
7
|
import { AppHeaderListItem } from '../AppHeader/AppHeaderElements/AppHeaderListItem';
|
|
8
8
|
import { useHeaderSearch } from '../AppHeader/Search/useHeaderSearch';
|
|
9
9
|
import { appHeaderMobileBreakpoint, StyledAppBar } from '../AppHeader/shared';
|
|
10
10
|
import { mapAppHeaderItemToElement } from '../AppHeader/shared/utils';
|
|
11
11
|
import { AppHeaderMainMenuMobile } from '../AppHeaderMobile/AppHeaderMainMenuMobile';
|
|
12
|
-
import { GlobalNavRedesignContext } from '../GlobalHeader';
|
|
13
12
|
import { HeaderHeightArea } from '../HeaderHeightArea';
|
|
14
13
|
import { NotificationsContents } from '../Notifications/NotificationsContents';
|
|
15
14
|
import { useHeaderNotifications } from '../Notifications/useHeaderNotifications';
|
|
16
15
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
17
16
|
const StyledOverlay = /*#__PURE__*/_styled(Overlay, {
|
|
18
|
-
target: "
|
|
17
|
+
target: "e14c9jns1",
|
|
19
18
|
label: "StyledOverlay"
|
|
20
19
|
})(css({
|
|
21
20
|
display: {
|
|
@@ -25,24 +24,12 @@ const StyledOverlay = /*#__PURE__*/_styled(Overlay, {
|
|
|
25
24
|
width: `100vw`,
|
|
26
25
|
height: `100vh`,
|
|
27
26
|
opacity: 1,
|
|
28
|
-
bg: `
|
|
27
|
+
bg: `beige`,
|
|
29
28
|
position: `fixed`,
|
|
30
29
|
left: 0,
|
|
31
30
|
top: 0,
|
|
32
31
|
overflowX: `hidden`
|
|
33
|
-
}), states({
|
|
34
|
-
displayGlobalNavRedesign: {
|
|
35
|
-
bg: 'beige'
|
|
36
|
-
}
|
|
37
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/AppHeaderMobile/index.tsx"],"names":[],"mappings":"AAuDsB","file":"../../src/AppHeaderMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ButtonBaseElements,\n  ContentContainer,\n  IconButton,\n  Overlay,\n} from '@codecademy/gamut';\nimport { MenuIcon } from '@codecademy/gamut-icons';\nimport {\n  Background,\n  css,\n  states,\n  theme,\n  useColorModes,\n} from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef, useState } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderSearch } from '..';\nimport { AppHeaderListItem } from '../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { useHeaderSearch } from '../AppHeader/Search/useHeaderSearch';\nimport {\n  AppHeaderAction,\n  AppHeaderItem,\n  appHeaderMobileBreakpoint,\n  FormattedMobileAppHeaderItems,\n  StyledAppBar,\n} from '../AppHeader/shared';\nimport { mapAppHeaderItemToElement } from '../AppHeader/shared/utils';\nimport { AppHeaderMainMenuMobile } from '../AppHeaderMobile/AppHeaderMainMenuMobile';\nimport {\n  GlobalNavRedesignContext,\n  NavigationMenuFormattedLabel,\n} from '../GlobalHeader';\nimport { HeaderHeightArea } from '../HeaderHeightArea';\nimport { NotificationsContents } from '../Notifications/NotificationsContents';\nimport { AppHeaderNotificationSettings } from '../Notifications/types';\nimport { useHeaderNotifications } from '../Notifications/useHeaderNotifications';\n\nexport type AppHeaderMobileProps = AppHeaderAction & {\n  items: FormattedMobileAppHeaderItems;\n  notifications?: AppHeaderNotificationSettings;\n  redirectParam?: string;\n  search: AppHeaderSearch;\n  isAnon: boolean;\n  /**\n   * used to conditonally hide the default search icon and notification bell\n   */\n  isEnterprise?: boolean;\n  isSimple?: boolean;\n  hideRightMenuButton?: boolean;\n  navigationMenuFormattedLabel?: NavigationMenuFormattedLabel;\n};\n\nconst StyledOverlay = styled(Overlay)<{ displayGlobalNavRedesign: boolean }>(\n  css({\n    display: { _: `block`, [appHeaderMobileBreakpoint]: `none` },\n    width: `100vw`,\n    height: `100vh`,\n    opacity: 1,\n    bg: `background`,\n    position: `fixed`,\n    left: 0,\n    top: 0,\n    overflowX: `hidden`,\n  }),\n  states({\n    displayGlobalNavRedesign: {\n      bg: 'beige',\n    },\n  })\n);\n\nconst StyledContentContainer = styled(ContentContainer)(\n  css({\n    display: `flex`,\n    flexDirection: `column`,\n    p: 0,\n  })\n);\n\nconst StyledNavBar = styled.ul<{ center?: boolean }>(\n  css({\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n    alignItems: 'center',\n  }),\n  states({\n    center: {\n      justifyContent: {\n        _: 'center',\n        sm: 'flex-start',\n      },\n    },\n  })\n);\n\nexport const AppHeaderMobile: React.FC<AppHeaderMobileProps> = ({\n  action,\n  items,\n  notifications,\n  search,\n  redirectParam,\n  isAnon,\n  isEnterprise,\n  isSimple,\n  hideRightMenuButton,\n  navigationMenuFormattedLabel,\n}) => {\n  const [mode, , modes] = useColorModes();\n  const bgCurrent = modes[mode]['background-current'];\n  const [mobileMenuOpen, setMobileMenuOpen] = useState<boolean | undefined>(\n    undefined\n  );\n  const [allowScroll, setAllowScroll] = useState<boolean>(false);\n  const openButtonRef = useRef<ButtonBaseElements>(null);\n  const closeButtonRef = useRef<ButtonBaseElements>(null);\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const [notificationsBell, notificationsView] = useHeaderNotifications({\n    settings: notifications,\n    Renderer: NotificationsContents,\n  });\n\n  const [searchButton, searchPane] = useHeaderSearch({\n    ...search,\n  });\n\n  const openMobileMenu = () => {\n    setMobileMenuOpen(true);\n\n    if (closeButtonRef.current) {\n      closeButtonRef.current.focus();\n    }\n  };\n\n  useEffect(() => {\n    if (mobileMenuOpen === false && openButtonRef.current) {\n      setTimeout(() => {\n        if (openButtonRef.current) openButtonRef.current.focus();\n      }, 0);\n    }\n  }, [mobileMenuOpen]);\n\n  const mapItemsToElement = <T extends AppHeaderItem[]>(\n    items: T,\n    side: 'left' | 'right',\n    hideExtraItems?: boolean\n  ) => {\n    const shouldHideItems = hideExtraItems === true && items.length > 1;\n    return items.map((item, index) => {\n      const isLastItem = index + 1 === items.length;\n      const isHidable = !isLastItem && shouldHideItems;\n      return (\n        <AppHeaderListItem\n          key={item.id}\n          ml={side === 'right' && index === 0 ? 'auto' : 0}\n          display={{\n            _: isHidable ? 'none' : 'flex',\n            xs: 'flex',\n          }}\n        >\n          {mapAppHeaderItemToElement({\n            action,\n            isAnon,\n            isStandalone: undefined,\n            isTeams: undefined,\n            item,\n            mobile: true,\n            onKeyDown: undefined,\n            redirectParam,\n          })}\n        </AppHeaderListItem>\n      );\n    });\n  };\n\n  const right = [\n    ...(!isEnterprise ? [searchButton] : []),\n    ...(notificationsBell && !isEnterprise ? [notificationsBell] : []),\n    ...items.right,\n  ];\n\n  const onItemType = (type: string | undefined) => {\n    if (\n      type &&\n      (type === 'catalog-dropdown' || type === 'resources-dropdown')\n    ) {\n      setAllowScroll(true);\n    } else {\n      setAllowScroll(false);\n    }\n  };\n\n  return (\n    <>\n      {!mobileMenuOpen && ( // need this bc AppBar has a hardcoded z-Index of 15\n        <HeaderHeightArea\n          display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n        >\n          <StyledAppBar as=\"nav\" aria-label=\"Main\">\n            <StyledNavBar center={!!isSimple}>\n              {mapItemsToElement(items.left, 'left')}\n              {mapItemsToElement(right, 'right', true)}\n              {!hideRightMenuButton && (\n                <AppHeaderListItem ml={right.length === 0 ? 'auto' : 0}>\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={'Site\\nnavigation'}\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    data-testid=\"header-mobile-menu\"\n                    onClick={() => {\n                      openMobileMenu();\n                    }}\n                    icon={MenuIcon}\n                    variant=\"interface\"\n                    ref={openButtonRef}\n                  />\n                </AppHeaderListItem>\n              )}\n            </StyledNavBar>\n          </StyledAppBar>\n        </HeaderHeightArea>\n      )}\n      <StyledOverlay\n        displayGlobalNavRedesign={displayGlobalNavRedesign}\n        clickOutsideCloses\n        escapeCloses\n        isOpen={mobileMenuOpen}\n        onRequestClose={() => setMobileMenuOpen(false)}\n        allowScroll={allowScroll}\n      >\n        <Background bg={displayGlobalNavRedesign ? 'beige' : bgCurrent}>\n          <HeaderHeightArea\n            display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n            as=\"nav\"\n            ariaLabel=\"Main\"\n            data-testid=\"header-mobile-menu-dropdown\"\n          >\n            <StyledAppBar>\n              <StyledNavBar>\n                {mapItemsToElement(items.left, 'left')}\n                <AppHeaderListItem ml=\"auto\">\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    onClick={() => {\n                      setMobileMenuOpen(false);\n                    }}\n                    icon={MenuIcon}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    ref={closeButtonRef}\n                  />\n                </AppHeaderListItem>\n              </StyledNavBar>\n            </StyledAppBar>\n            {displayGlobalNavRedesign ? (\n              <Box background={theme.colors.beige} height=\"auto\">\n                <AppHeaderMainMenuMobile\n                  action={action}\n                  items={items.mainMenu}\n                  getItemType={onItemType}\n                  isAnon={isAnon}\n                  handleCloseMainMenu={() => setMobileMenuOpen(false)}\n                />\n              </Box>\n            ) : (\n              <StyledContentContainer size=\"small\">\n                <AppHeaderMainMenuMobile\n                  action={action}\n                  items={items.mainMenu}\n                  getItemType={onItemType}\n                  isAnon={isAnon}\n                  handleCloseMainMenu={() => setMobileMenuOpen(false)}\n                />\n              </StyledContentContainer>\n            )}\n          </HeaderHeightArea>\n        </Background>\n      </StyledOverlay>\n      {!isEnterprise && (\n        <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n          {searchPane}\n        </Box>\n      )}\n      <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n        {notificationsView}\n      </Box>\n    </>\n  );\n};\n"]} */");
|
|
38
|
-
const StyledContentContainer = /*#__PURE__*/_styled(ContentContainer, {
|
|
39
|
-
target: "e14c9jns1",
|
|
40
|
-
label: "StyledContentContainer"
|
|
41
|
-
})(css({
|
|
42
|
-
display: `flex`,
|
|
43
|
-
flexDirection: `column`,
|
|
44
|
-
p: 0
|
|
45
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/AppHeaderMobile/index.tsx"],"names":[],"mappings":"AA0E+B","file":"../../src/AppHeaderMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ButtonBaseElements,\n  ContentContainer,\n  IconButton,\n  Overlay,\n} from '@codecademy/gamut';\nimport { MenuIcon } from '@codecademy/gamut-icons';\nimport {\n  Background,\n  css,\n  states,\n  theme,\n  useColorModes,\n} from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef, useState } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderSearch } from '..';\nimport { AppHeaderListItem } from '../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { useHeaderSearch } from '../AppHeader/Search/useHeaderSearch';\nimport {\n  AppHeaderAction,\n  AppHeaderItem,\n  appHeaderMobileBreakpoint,\n  FormattedMobileAppHeaderItems,\n  StyledAppBar,\n} from '../AppHeader/shared';\nimport { mapAppHeaderItemToElement } from '../AppHeader/shared/utils';\nimport { AppHeaderMainMenuMobile } from '../AppHeaderMobile/AppHeaderMainMenuMobile';\nimport {\n  GlobalNavRedesignContext,\n  NavigationMenuFormattedLabel,\n} from '../GlobalHeader';\nimport { HeaderHeightArea } from '../HeaderHeightArea';\nimport { NotificationsContents } from '../Notifications/NotificationsContents';\nimport { AppHeaderNotificationSettings } from '../Notifications/types';\nimport { useHeaderNotifications } from '../Notifications/useHeaderNotifications';\n\nexport type AppHeaderMobileProps = AppHeaderAction & {\n  items: FormattedMobileAppHeaderItems;\n  notifications?: AppHeaderNotificationSettings;\n  redirectParam?: string;\n  search: AppHeaderSearch;\n  isAnon: boolean;\n  /**\n   * used to conditonally hide the default search icon and notification bell\n   */\n  isEnterprise?: boolean;\n  isSimple?: boolean;\n  hideRightMenuButton?: boolean;\n  navigationMenuFormattedLabel?: NavigationMenuFormattedLabel;\n};\n\nconst StyledOverlay = styled(Overlay)<{ displayGlobalNavRedesign: boolean }>(\n  css({\n    display: { _: `block`, [appHeaderMobileBreakpoint]: `none` },\n    width: `100vw`,\n    height: `100vh`,\n    opacity: 1,\n    bg: `background`,\n    position: `fixed`,\n    left: 0,\n    top: 0,\n    overflowX: `hidden`,\n  }),\n  states({\n    displayGlobalNavRedesign: {\n      bg: 'beige',\n    },\n  })\n);\n\nconst StyledContentContainer = styled(ContentContainer)(\n  css({\n    display: `flex`,\n    flexDirection: `column`,\n    p: 0,\n  })\n);\n\nconst StyledNavBar = styled.ul<{ center?: boolean }>(\n  css({\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n    alignItems: 'center',\n  }),\n  states({\n    center: {\n      justifyContent: {\n        _: 'center',\n        sm: 'flex-start',\n      },\n    },\n  })\n);\n\nexport const AppHeaderMobile: React.FC<AppHeaderMobileProps> = ({\n  action,\n  items,\n  notifications,\n  search,\n  redirectParam,\n  isAnon,\n  isEnterprise,\n  isSimple,\n  hideRightMenuButton,\n  navigationMenuFormattedLabel,\n}) => {\n  const [mode, , modes] = useColorModes();\n  const bgCurrent = modes[mode]['background-current'];\n  const [mobileMenuOpen, setMobileMenuOpen] = useState<boolean | undefined>(\n    undefined\n  );\n  const [allowScroll, setAllowScroll] = useState<boolean>(false);\n  const openButtonRef = useRef<ButtonBaseElements>(null);\n  const closeButtonRef = useRef<ButtonBaseElements>(null);\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const [notificationsBell, notificationsView] = useHeaderNotifications({\n    settings: notifications,\n    Renderer: NotificationsContents,\n  });\n\n  const [searchButton, searchPane] = useHeaderSearch({\n    ...search,\n  });\n\n  const openMobileMenu = () => {\n    setMobileMenuOpen(true);\n\n    if (closeButtonRef.current) {\n      closeButtonRef.current.focus();\n    }\n  };\n\n  useEffect(() => {\n    if (mobileMenuOpen === false && openButtonRef.current) {\n      setTimeout(() => {\n        if (openButtonRef.current) openButtonRef.current.focus();\n      }, 0);\n    }\n  }, [mobileMenuOpen]);\n\n  const mapItemsToElement = <T extends AppHeaderItem[]>(\n    items: T,\n    side: 'left' | 'right',\n    hideExtraItems?: boolean\n  ) => {\n    const shouldHideItems = hideExtraItems === true && items.length > 1;\n    return items.map((item, index) => {\n      const isLastItem = index + 1 === items.length;\n      const isHidable = !isLastItem && shouldHideItems;\n      return (\n        <AppHeaderListItem\n          key={item.id}\n          ml={side === 'right' && index === 0 ? 'auto' : 0}\n          display={{\n            _: isHidable ? 'none' : 'flex',\n            xs: 'flex',\n          }}\n        >\n          {mapAppHeaderItemToElement({\n            action,\n            isAnon,\n            isStandalone: undefined,\n            isTeams: undefined,\n            item,\n            mobile: true,\n            onKeyDown: undefined,\n            redirectParam,\n          })}\n        </AppHeaderListItem>\n      );\n    });\n  };\n\n  const right = [\n    ...(!isEnterprise ? [searchButton] : []),\n    ...(notificationsBell && !isEnterprise ? [notificationsBell] : []),\n    ...items.right,\n  ];\n\n  const onItemType = (type: string | undefined) => {\n    if (\n      type &&\n      (type === 'catalog-dropdown' || type === 'resources-dropdown')\n    ) {\n      setAllowScroll(true);\n    } else {\n      setAllowScroll(false);\n    }\n  };\n\n  return (\n    <>\n      {!mobileMenuOpen && ( // need this bc AppBar has a hardcoded z-Index of 15\n        <HeaderHeightArea\n          display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n        >\n          <StyledAppBar as=\"nav\" aria-label=\"Main\">\n            <StyledNavBar center={!!isSimple}>\n              {mapItemsToElement(items.left, 'left')}\n              {mapItemsToElement(right, 'right', true)}\n              {!hideRightMenuButton && (\n                <AppHeaderListItem ml={right.length === 0 ? 'auto' : 0}>\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={'Site\\nnavigation'}\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    data-testid=\"header-mobile-menu\"\n                    onClick={() => {\n                      openMobileMenu();\n                    }}\n                    icon={MenuIcon}\n                    variant=\"interface\"\n                    ref={openButtonRef}\n                  />\n                </AppHeaderListItem>\n              )}\n            </StyledNavBar>\n          </StyledAppBar>\n        </HeaderHeightArea>\n      )}\n      <StyledOverlay\n        displayGlobalNavRedesign={displayGlobalNavRedesign}\n        clickOutsideCloses\n        escapeCloses\n        isOpen={mobileMenuOpen}\n        onRequestClose={() => setMobileMenuOpen(false)}\n        allowScroll={allowScroll}\n      >\n        <Background bg={displayGlobalNavRedesign ? 'beige' : bgCurrent}>\n          <HeaderHeightArea\n            display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n            as=\"nav\"\n            ariaLabel=\"Main\"\n            data-testid=\"header-mobile-menu-dropdown\"\n          >\n            <StyledAppBar>\n              <StyledNavBar>\n                {mapItemsToElement(items.left, 'left')}\n                <AppHeaderListItem ml=\"auto\">\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    onClick={() => {\n                      setMobileMenuOpen(false);\n                    }}\n                    icon={MenuIcon}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    ref={closeButtonRef}\n                  />\n                </AppHeaderListItem>\n              </StyledNavBar>\n            </StyledAppBar>\n            {displayGlobalNavRedesign ? (\n              <Box background={theme.colors.beige} height=\"auto\">\n                <AppHeaderMainMenuMobile\n                  action={action}\n                  items={items.mainMenu}\n                  getItemType={onItemType}\n                  isAnon={isAnon}\n                  handleCloseMainMenu={() => setMobileMenuOpen(false)}\n                />\n              </Box>\n            ) : (\n              <StyledContentContainer size=\"small\">\n                <AppHeaderMainMenuMobile\n                  action={action}\n                  items={items.mainMenu}\n                  getItemType={onItemType}\n                  isAnon={isAnon}\n                  handleCloseMainMenu={() => setMobileMenuOpen(false)}\n                />\n              </StyledContentContainer>\n            )}\n          </HeaderHeightArea>\n        </Background>\n      </StyledOverlay>\n      {!isEnterprise && (\n        <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n          {searchPane}\n        </Box>\n      )}\n      <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n        {notificationsView}\n      </Box>\n    </>\n  );\n};\n"]} */");
|
|
32
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/AppHeaderMobile/index.tsx"],"names":[],"mappings":"AA6CsB","file":"../../src/AppHeaderMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ButtonBaseElements,\n  IconButton,\n  Overlay,\n} from '@codecademy/gamut';\nimport { MenuIcon } from '@codecademy/gamut-icons';\nimport { Background, css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useEffect, useRef, useState } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderSearch } from '..';\nimport { AppHeaderListItem } from '../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { useHeaderSearch } from '../AppHeader/Search/useHeaderSearch';\nimport {\n  AppHeaderAction,\n  AppHeaderItem,\n  appHeaderMobileBreakpoint,\n  FormattedMobileAppHeaderItems,\n  StyledAppBar,\n} from '../AppHeader/shared';\nimport { mapAppHeaderItemToElement } from '../AppHeader/shared/utils';\nimport { AppHeaderMainMenuMobile } from '../AppHeaderMobile/AppHeaderMainMenuMobile';\nimport { NavigationMenuFormattedLabel } from '../GlobalHeader';\nimport { HeaderHeightArea } from '../HeaderHeightArea';\nimport { NotificationsContents } from '../Notifications/NotificationsContents';\nimport { AppHeaderNotificationSettings } from '../Notifications/types';\nimport { useHeaderNotifications } from '../Notifications/useHeaderNotifications';\n\nexport type AppHeaderMobileProps = AppHeaderAction & {\n  items: FormattedMobileAppHeaderItems;\n  notifications?: AppHeaderNotificationSettings;\n  redirectParam?: string;\n  search: AppHeaderSearch;\n  isAnon: boolean;\n  /**\n   * used to conditonally hide the default search icon and notification bell\n   */\n  isEnterprise?: boolean;\n  isSimple?: boolean;\n  hideRightMenuButton?: boolean;\n  navigationMenuFormattedLabel?: NavigationMenuFormattedLabel;\n};\n\nconst StyledOverlay = styled(Overlay)(\n  css({\n    display: { _: `block`, [appHeaderMobileBreakpoint]: `none` },\n    width: `100vw`,\n    height: `100vh`,\n    opacity: 1,\n    bg: `beige`,\n    position: `fixed`,\n    left: 0,\n    top: 0,\n    overflowX: `hidden`,\n  })\n);\n\nconst StyledNavBar = styled.ul<{ center?: boolean }>(\n  css({\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n    alignItems: 'center',\n  }),\n  states({\n    center: {\n      justifyContent: {\n        _: 'center',\n        sm: 'flex-start',\n      },\n    },\n  })\n);\n\nexport const AppHeaderMobile: React.FC<AppHeaderMobileProps> = ({\n  action,\n  items,\n  notifications,\n  search,\n  redirectParam,\n  isAnon,\n  isEnterprise,\n  isSimple,\n  hideRightMenuButton,\n  navigationMenuFormattedLabel,\n}) => {\n  const [mobileMenuOpen, setMobileMenuOpen] = useState<boolean | undefined>(\n    undefined\n  );\n  const [allowScroll, setAllowScroll] = useState<boolean>(false);\n  const openButtonRef = useRef<ButtonBaseElements>(null);\n  const closeButtonRef = useRef<ButtonBaseElements>(null);\n\n  const [notificationsBell, notificationsView] = useHeaderNotifications({\n    settings: notifications,\n    Renderer: NotificationsContents,\n  });\n\n  const [searchButton, searchPane] = useHeaderSearch({\n    ...search,\n  });\n\n  const openMobileMenu = () => {\n    setMobileMenuOpen(true);\n\n    if (closeButtonRef.current) {\n      closeButtonRef.current.focus();\n    }\n  };\n\n  useEffect(() => {\n    if (mobileMenuOpen === false && openButtonRef.current) {\n      setTimeout(() => {\n        if (openButtonRef.current) openButtonRef.current.focus();\n      }, 0);\n    }\n  }, [mobileMenuOpen]);\n\n  const mapItemsToElement = <T extends AppHeaderItem[]>(\n    items: T,\n    side: 'left' | 'right',\n    hideExtraItems?: boolean\n  ) => {\n    const shouldHideItems = hideExtraItems === true && items.length > 1;\n    return items.map((item, index) => {\n      const isLastItem = index + 1 === items.length;\n      const isHidable = !isLastItem && shouldHideItems;\n      return (\n        <AppHeaderListItem\n          key={item.id}\n          ml={side === 'right' && index === 0 ? 'auto' : 0}\n          display={{\n            _: isHidable ? 'none' : 'flex',\n            xs: 'flex',\n          }}\n        >\n          {mapAppHeaderItemToElement({\n            action,\n            isStandalone: undefined,\n            isTeams: undefined,\n            item,\n            mobile: true,\n            onKeyDown: undefined,\n            redirectParam,\n          })}\n        </AppHeaderListItem>\n      );\n    });\n  };\n\n  const right = [\n    ...(!isEnterprise ? [searchButton] : []),\n    ...(notificationsBell && !isEnterprise ? [notificationsBell] : []),\n    ...items.right,\n  ];\n\n  const onItemType = (type: string | undefined) => {\n    if (\n      type &&\n      (type === 'catalog-dropdown' || type === 'resources-dropdown')\n    ) {\n      setAllowScroll(true);\n    } else {\n      setAllowScroll(false);\n    }\n  };\n\n  return (\n    <>\n      {!mobileMenuOpen && ( // need this bc AppBar has a hardcoded z-Index of 15\n        <HeaderHeightArea\n          display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n        >\n          <StyledAppBar as=\"nav\" aria-label=\"Main\">\n            <StyledNavBar center={!!isSimple}>\n              {mapItemsToElement(items.left, 'left')}\n              {mapItemsToElement(right, 'right', true)}\n              {!hideRightMenuButton && (\n                <AppHeaderListItem ml={right.length === 0 ? 'auto' : 0}>\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={'Site\\nnavigation'}\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    data-testid=\"header-mobile-menu\"\n                    onClick={() => {\n                      openMobileMenu();\n                    }}\n                    icon={MenuIcon}\n                    variant=\"interface\"\n                    ref={openButtonRef}\n                  />\n                </AppHeaderListItem>\n              )}\n            </StyledNavBar>\n          </StyledAppBar>\n        </HeaderHeightArea>\n      )}\n      <StyledOverlay\n        clickOutsideCloses\n        escapeCloses\n        isOpen={mobileMenuOpen}\n        onRequestClose={() => setMobileMenuOpen(false)}\n        allowScroll={allowScroll}\n      >\n        <Background bg=\"beige\">\n          <HeaderHeightArea\n            display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n            as=\"nav\"\n            ariaLabel=\"Main\"\n            data-testid=\"header-mobile-menu-dropdown\"\n          >\n            <StyledAppBar>\n              <StyledNavBar>\n                {mapItemsToElement(items.left, 'left')}\n                <AppHeaderListItem ml=\"auto\">\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    onClick={() => {\n                      setMobileMenuOpen(false);\n                    }}\n                    icon={MenuIcon}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    ref={closeButtonRef}\n                  />\n                </AppHeaderListItem>\n              </StyledNavBar>\n            </StyledAppBar>\n            <Box background={theme.colors.beige} height=\"auto\">\n              <AppHeaderMainMenuMobile\n                action={action}\n                items={items.mainMenu}\n                getItemType={onItemType}\n                isAnon={isAnon}\n              />\n            </Box>\n          </HeaderHeightArea>\n        </Background>\n      </StyledOverlay>\n      {!isEnterprise && (\n        <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n          {searchPane}\n        </Box>\n      )}\n      <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n        {notificationsView}\n      </Box>\n    </>\n  );\n};\n"]} */");
|
|
46
33
|
const StyledNavBar = /*#__PURE__*/_styled("ul", {
|
|
47
34
|
target: "e14c9jns0",
|
|
48
35
|
label: "StyledNavBar"
|
|
@@ -60,7 +47,7 @@ const StyledNavBar = /*#__PURE__*/_styled("ul", {
|
|
|
60
47
|
sm: 'flex-start'
|
|
61
48
|
}
|
|
62
49
|
}
|
|
63
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/AppHeaderMobile/index.tsx"],"names":[],"mappings":"AAkFqB","file":"../../src/AppHeaderMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ButtonBaseElements,\n  ContentContainer,\n  IconButton,\n  Overlay,\n} from '@codecademy/gamut';\nimport { MenuIcon } from '@codecademy/gamut-icons';\nimport {\n  Background,\n  css,\n  states,\n  theme,\n  useColorModes,\n} from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef, useState } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderSearch } from '..';\nimport { AppHeaderListItem } from '../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { useHeaderSearch } from '../AppHeader/Search/useHeaderSearch';\nimport {\n  AppHeaderAction,\n  AppHeaderItem,\n  appHeaderMobileBreakpoint,\n  FormattedMobileAppHeaderItems,\n  StyledAppBar,\n} from '../AppHeader/shared';\nimport { mapAppHeaderItemToElement } from '../AppHeader/shared/utils';\nimport { AppHeaderMainMenuMobile } from '../AppHeaderMobile/AppHeaderMainMenuMobile';\nimport {\n  GlobalNavRedesignContext,\n  NavigationMenuFormattedLabel,\n} from '../GlobalHeader';\nimport { HeaderHeightArea } from '../HeaderHeightArea';\nimport { NotificationsContents } from '../Notifications/NotificationsContents';\nimport { AppHeaderNotificationSettings } from '../Notifications/types';\nimport { useHeaderNotifications } from '../Notifications/useHeaderNotifications';\n\nexport type AppHeaderMobileProps = AppHeaderAction & {\n  items: FormattedMobileAppHeaderItems;\n  notifications?: AppHeaderNotificationSettings;\n  redirectParam?: string;\n  search: AppHeaderSearch;\n  isAnon: boolean;\n  /**\n   * used to conditonally hide the default search icon and notification bell\n   */\n  isEnterprise?: boolean;\n  isSimple?: boolean;\n  hideRightMenuButton?: boolean;\n  navigationMenuFormattedLabel?: NavigationMenuFormattedLabel;\n};\n\nconst StyledOverlay = styled(Overlay)<{ displayGlobalNavRedesign: boolean }>(\n  css({\n    display: { _: `block`, [appHeaderMobileBreakpoint]: `none` },\n    width: `100vw`,\n    height: `100vh`,\n    opacity: 1,\n    bg: `background`,\n    position: `fixed`,\n    left: 0,\n    top: 0,\n    overflowX: `hidden`,\n  }),\n  states({\n    displayGlobalNavRedesign: {\n      bg: 'beige',\n    },\n  })\n);\n\nconst StyledContentContainer = styled(ContentContainer)(\n  css({\n    display: `flex`,\n    flexDirection: `column`,\n    p: 0,\n  })\n);\n\nconst StyledNavBar = styled.ul<{ center?: boolean }>(\n  css({\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n    alignItems: 'center',\n  }),\n  states({\n    center: {\n      justifyContent: {\n        _: 'center',\n        sm: 'flex-start',\n      },\n    },\n  })\n);\n\nexport const AppHeaderMobile: React.FC<AppHeaderMobileProps> = ({\n  action,\n  items,\n  notifications,\n  search,\n  redirectParam,\n  isAnon,\n  isEnterprise,\n  isSimple,\n  hideRightMenuButton,\n  navigationMenuFormattedLabel,\n}) => {\n  const [mode, , modes] = useColorModes();\n  const bgCurrent = modes[mode]['background-current'];\n  const [mobileMenuOpen, setMobileMenuOpen] = useState<boolean | undefined>(\n    undefined\n  );\n  const [allowScroll, setAllowScroll] = useState<boolean>(false);\n  const openButtonRef = useRef<ButtonBaseElements>(null);\n  const closeButtonRef = useRef<ButtonBaseElements>(null);\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const [notificationsBell, notificationsView] = useHeaderNotifications({\n    settings: notifications,\n    Renderer: NotificationsContents,\n  });\n\n  const [searchButton, searchPane] = useHeaderSearch({\n    ...search,\n  });\n\n  const openMobileMenu = () => {\n    setMobileMenuOpen(true);\n\n    if (closeButtonRef.current) {\n      closeButtonRef.current.focus();\n    }\n  };\n\n  useEffect(() => {\n    if (mobileMenuOpen === false && openButtonRef.current) {\n      setTimeout(() => {\n        if (openButtonRef.current) openButtonRef.current.focus();\n      }, 0);\n    }\n  }, [mobileMenuOpen]);\n\n  const mapItemsToElement = <T extends AppHeaderItem[]>(\n    items: T,\n    side: 'left' | 'right',\n    hideExtraItems?: boolean\n  ) => {\n    const shouldHideItems = hideExtraItems === true && items.length > 1;\n    return items.map((item, index) => {\n      const isLastItem = index + 1 === items.length;\n      const isHidable = !isLastItem && shouldHideItems;\n      return (\n        <AppHeaderListItem\n          key={item.id}\n          ml={side === 'right' && index === 0 ? 'auto' : 0}\n          display={{\n            _: isHidable ? 'none' : 'flex',\n            xs: 'flex',\n          }}\n        >\n          {mapAppHeaderItemToElement({\n            action,\n            isAnon,\n            isStandalone: undefined,\n            isTeams: undefined,\n            item,\n            mobile: true,\n            onKeyDown: undefined,\n            redirectParam,\n          })}\n        </AppHeaderListItem>\n      );\n    });\n  };\n\n  const right = [\n    ...(!isEnterprise ? [searchButton] : []),\n    ...(notificationsBell && !isEnterprise ? [notificationsBell] : []),\n    ...items.right,\n  ];\n\n  const onItemType = (type: string | undefined) => {\n    if (\n      type &&\n      (type === 'catalog-dropdown' || type === 'resources-dropdown')\n    ) {\n      setAllowScroll(true);\n    } else {\n      setAllowScroll(false);\n    }\n  };\n\n  return (\n    <>\n      {!mobileMenuOpen && ( // need this bc AppBar has a hardcoded z-Index of 15\n        <HeaderHeightArea\n          display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n        >\n          <StyledAppBar as=\"nav\" aria-label=\"Main\">\n            <StyledNavBar center={!!isSimple}>\n              {mapItemsToElement(items.left, 'left')}\n              {mapItemsToElement(right, 'right', true)}\n              {!hideRightMenuButton && (\n                <AppHeaderListItem ml={right.length === 0 ? 'auto' : 0}>\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={'Site\\nnavigation'}\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    data-testid=\"header-mobile-menu\"\n                    onClick={() => {\n                      openMobileMenu();\n                    }}\n                    icon={MenuIcon}\n                    variant=\"interface\"\n                    ref={openButtonRef}\n                  />\n                </AppHeaderListItem>\n              )}\n            </StyledNavBar>\n          </StyledAppBar>\n        </HeaderHeightArea>\n      )}\n      <StyledOverlay\n        displayGlobalNavRedesign={displayGlobalNavRedesign}\n        clickOutsideCloses\n        escapeCloses\n        isOpen={mobileMenuOpen}\n        onRequestClose={() => setMobileMenuOpen(false)}\n        allowScroll={allowScroll}\n      >\n        <Background bg={displayGlobalNavRedesign ? 'beige' : bgCurrent}>\n          <HeaderHeightArea\n            display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n            as=\"nav\"\n            ariaLabel=\"Main\"\n            data-testid=\"header-mobile-menu-dropdown\"\n          >\n            <StyledAppBar>\n              <StyledNavBar>\n                {mapItemsToElement(items.left, 'left')}\n                <AppHeaderListItem ml=\"auto\">\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    onClick={() => {\n                      setMobileMenuOpen(false);\n                    }}\n                    icon={MenuIcon}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    ref={closeButtonRef}\n                  />\n                </AppHeaderListItem>\n              </StyledNavBar>\n            </StyledAppBar>\n            {displayGlobalNavRedesign ? (\n              <Box background={theme.colors.beige} height=\"auto\">\n                <AppHeaderMainMenuMobile\n                  action={action}\n                  items={items.mainMenu}\n                  getItemType={onItemType}\n                  isAnon={isAnon}\n                  handleCloseMainMenu={() => setMobileMenuOpen(false)}\n                />\n              </Box>\n            ) : (\n              <StyledContentContainer size=\"small\">\n                <AppHeaderMainMenuMobile\n                  action={action}\n                  items={items.mainMenu}\n                  getItemType={onItemType}\n                  isAnon={isAnon}\n                  handleCloseMainMenu={() => setMobileMenuOpen(false)}\n                />\n              </StyledContentContainer>\n            )}\n          </HeaderHeightArea>\n        </Background>\n      </StyledOverlay>\n      {!isEnterprise && (\n        <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n          {searchPane}\n        </Box>\n      )}\n      <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n        {notificationsView}\n      </Box>\n    </>\n  );\n};\n"]} */");
|
|
50
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/AppHeaderMobile/index.tsx"],"names":[],"mappings":"AA2DqB","file":"../../src/AppHeaderMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ButtonBaseElements,\n  IconButton,\n  Overlay,\n} from '@codecademy/gamut';\nimport { MenuIcon } from '@codecademy/gamut-icons';\nimport { Background, css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useEffect, useRef, useState } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderSearch } from '..';\nimport { AppHeaderListItem } from '../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { useHeaderSearch } from '../AppHeader/Search/useHeaderSearch';\nimport {\n  AppHeaderAction,\n  AppHeaderItem,\n  appHeaderMobileBreakpoint,\n  FormattedMobileAppHeaderItems,\n  StyledAppBar,\n} from '../AppHeader/shared';\nimport { mapAppHeaderItemToElement } from '../AppHeader/shared/utils';\nimport { AppHeaderMainMenuMobile } from '../AppHeaderMobile/AppHeaderMainMenuMobile';\nimport { NavigationMenuFormattedLabel } from '../GlobalHeader';\nimport { HeaderHeightArea } from '../HeaderHeightArea';\nimport { NotificationsContents } from '../Notifications/NotificationsContents';\nimport { AppHeaderNotificationSettings } from '../Notifications/types';\nimport { useHeaderNotifications } from '../Notifications/useHeaderNotifications';\n\nexport type AppHeaderMobileProps = AppHeaderAction & {\n  items: FormattedMobileAppHeaderItems;\n  notifications?: AppHeaderNotificationSettings;\n  redirectParam?: string;\n  search: AppHeaderSearch;\n  isAnon: boolean;\n  /**\n   * used to conditonally hide the default search icon and notification bell\n   */\n  isEnterprise?: boolean;\n  isSimple?: boolean;\n  hideRightMenuButton?: boolean;\n  navigationMenuFormattedLabel?: NavigationMenuFormattedLabel;\n};\n\nconst StyledOverlay = styled(Overlay)(\n  css({\n    display: { _: `block`, [appHeaderMobileBreakpoint]: `none` },\n    width: `100vw`,\n    height: `100vh`,\n    opacity: 1,\n    bg: `beige`,\n    position: `fixed`,\n    left: 0,\n    top: 0,\n    overflowX: `hidden`,\n  })\n);\n\nconst StyledNavBar = styled.ul<{ center?: boolean }>(\n  css({\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n    alignItems: 'center',\n  }),\n  states({\n    center: {\n      justifyContent: {\n        _: 'center',\n        sm: 'flex-start',\n      },\n    },\n  })\n);\n\nexport const AppHeaderMobile: React.FC<AppHeaderMobileProps> = ({\n  action,\n  items,\n  notifications,\n  search,\n  redirectParam,\n  isAnon,\n  isEnterprise,\n  isSimple,\n  hideRightMenuButton,\n  navigationMenuFormattedLabel,\n}) => {\n  const [mobileMenuOpen, setMobileMenuOpen] = useState<boolean | undefined>(\n    undefined\n  );\n  const [allowScroll, setAllowScroll] = useState<boolean>(false);\n  const openButtonRef = useRef<ButtonBaseElements>(null);\n  const closeButtonRef = useRef<ButtonBaseElements>(null);\n\n  const [notificationsBell, notificationsView] = useHeaderNotifications({\n    settings: notifications,\n    Renderer: NotificationsContents,\n  });\n\n  const [searchButton, searchPane] = useHeaderSearch({\n    ...search,\n  });\n\n  const openMobileMenu = () => {\n    setMobileMenuOpen(true);\n\n    if (closeButtonRef.current) {\n      closeButtonRef.current.focus();\n    }\n  };\n\n  useEffect(() => {\n    if (mobileMenuOpen === false && openButtonRef.current) {\n      setTimeout(() => {\n        if (openButtonRef.current) openButtonRef.current.focus();\n      }, 0);\n    }\n  }, [mobileMenuOpen]);\n\n  const mapItemsToElement = <T extends AppHeaderItem[]>(\n    items: T,\n    side: 'left' | 'right',\n    hideExtraItems?: boolean\n  ) => {\n    const shouldHideItems = hideExtraItems === true && items.length > 1;\n    return items.map((item, index) => {\n      const isLastItem = index + 1 === items.length;\n      const isHidable = !isLastItem && shouldHideItems;\n      return (\n        <AppHeaderListItem\n          key={item.id}\n          ml={side === 'right' && index === 0 ? 'auto' : 0}\n          display={{\n            _: isHidable ? 'none' : 'flex',\n            xs: 'flex',\n          }}\n        >\n          {mapAppHeaderItemToElement({\n            action,\n            isStandalone: undefined,\n            isTeams: undefined,\n            item,\n            mobile: true,\n            onKeyDown: undefined,\n            redirectParam,\n          })}\n        </AppHeaderListItem>\n      );\n    });\n  };\n\n  const right = [\n    ...(!isEnterprise ? [searchButton] : []),\n    ...(notificationsBell && !isEnterprise ? [notificationsBell] : []),\n    ...items.right,\n  ];\n\n  const onItemType = (type: string | undefined) => {\n    if (\n      type &&\n      (type === 'catalog-dropdown' || type === 'resources-dropdown')\n    ) {\n      setAllowScroll(true);\n    } else {\n      setAllowScroll(false);\n    }\n  };\n\n  return (\n    <>\n      {!mobileMenuOpen && ( // need this bc AppBar has a hardcoded z-Index of 15\n        <HeaderHeightArea\n          display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n        >\n          <StyledAppBar as=\"nav\" aria-label=\"Main\">\n            <StyledNavBar center={!!isSimple}>\n              {mapItemsToElement(items.left, 'left')}\n              {mapItemsToElement(right, 'right', true)}\n              {!hideRightMenuButton && (\n                <AppHeaderListItem ml={right.length === 0 ? 'auto' : 0}>\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={'Site\\nnavigation'}\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    data-testid=\"header-mobile-menu\"\n                    onClick={() => {\n                      openMobileMenu();\n                    }}\n                    icon={MenuIcon}\n                    variant=\"interface\"\n                    ref={openButtonRef}\n                  />\n                </AppHeaderListItem>\n              )}\n            </StyledNavBar>\n          </StyledAppBar>\n        </HeaderHeightArea>\n      )}\n      <StyledOverlay\n        clickOutsideCloses\n        escapeCloses\n        isOpen={mobileMenuOpen}\n        onRequestClose={() => setMobileMenuOpen(false)}\n        allowScroll={allowScroll}\n      >\n        <Background bg=\"beige\">\n          <HeaderHeightArea\n            display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}\n            as=\"nav\"\n            ariaLabel=\"Main\"\n            data-testid=\"header-mobile-menu-dropdown\"\n          >\n            <StyledAppBar>\n              <StyledNavBar>\n                {mapItemsToElement(items.left, 'left')}\n                <AppHeaderListItem ml=\"auto\">\n                  <IconButton\n                    aria-expanded={mobileMenuOpen}\n                    onClick={() => {\n                      setMobileMenuOpen(false);\n                    }}\n                    icon={MenuIcon}\n                    aria-label={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tip={\n                      navigationMenuFormattedLabel?.siteNavigation ||\n                      'Site navigation'\n                    }\n                    tipProps={{\n                      alignment: 'bottom-center',\n                      placement: 'floating',\n                    }}\n                    ref={closeButtonRef}\n                  />\n                </AppHeaderListItem>\n              </StyledNavBar>\n            </StyledAppBar>\n            <Box background={theme.colors.beige} height=\"auto\">\n              <AppHeaderMainMenuMobile\n                action={action}\n                items={items.mainMenu}\n                getItemType={onItemType}\n                isAnon={isAnon}\n              />\n            </Box>\n          </HeaderHeightArea>\n        </Background>\n      </StyledOverlay>\n      {!isEnterprise && (\n        <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n          {searchPane}\n        </Box>\n      )}\n      <Box display={{ _: `block`, [appHeaderMobileBreakpoint]: `none` }}>\n        {notificationsView}\n      </Box>\n    </>\n  );\n};\n"]} */");
|
|
64
51
|
export const AppHeaderMobile = ({
|
|
65
52
|
action,
|
|
66
53
|
items,
|
|
@@ -73,13 +60,10 @@ export const AppHeaderMobile = ({
|
|
|
73
60
|
hideRightMenuButton,
|
|
74
61
|
navigationMenuFormattedLabel
|
|
75
62
|
}) => {
|
|
76
|
-
const [mode,, modes] = useColorModes();
|
|
77
|
-
const bgCurrent = modes[mode]['background-current'];
|
|
78
63
|
const [mobileMenuOpen, setMobileMenuOpen] = useState(undefined);
|
|
79
64
|
const [allowScroll, setAllowScroll] = useState(false);
|
|
80
65
|
const openButtonRef = useRef(null);
|
|
81
66
|
const closeButtonRef = useRef(null);
|
|
82
|
-
const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);
|
|
83
67
|
const [notificationsBell, notificationsView] = useHeaderNotifications({
|
|
84
68
|
settings: notifications,
|
|
85
69
|
Renderer: NotificationsContents
|
|
@@ -113,7 +97,6 @@ export const AppHeaderMobile = ({
|
|
|
113
97
|
},
|
|
114
98
|
children: mapAppHeaderItemToElement({
|
|
115
99
|
action,
|
|
116
|
-
isAnon,
|
|
117
100
|
isStandalone: undefined,
|
|
118
101
|
isTeams: undefined,
|
|
119
102
|
item,
|
|
@@ -168,14 +151,13 @@ export const AppHeaderMobile = ({
|
|
|
168
151
|
})
|
|
169
152
|
})
|
|
170
153
|
}), /*#__PURE__*/_jsx(StyledOverlay, {
|
|
171
|
-
displayGlobalNavRedesign: displayGlobalNavRedesign,
|
|
172
154
|
clickOutsideCloses: true,
|
|
173
155
|
escapeCloses: true,
|
|
174
156
|
isOpen: mobileMenuOpen,
|
|
175
157
|
onRequestClose: () => setMobileMenuOpen(false),
|
|
176
158
|
allowScroll: allowScroll,
|
|
177
159
|
children: /*#__PURE__*/_jsx(Background, {
|
|
178
|
-
bg:
|
|
160
|
+
bg: "beige",
|
|
179
161
|
children: /*#__PURE__*/_jsxs(HeaderHeightArea, {
|
|
180
162
|
display: {
|
|
181
163
|
_: `block`,
|
|
@@ -204,24 +186,14 @@ export const AppHeaderMobile = ({
|
|
|
204
186
|
})
|
|
205
187
|
})]
|
|
206
188
|
})
|
|
207
|
-
}),
|
|
189
|
+
}), /*#__PURE__*/_jsx(Box, {
|
|
208
190
|
background: theme.colors.beige,
|
|
209
191
|
height: "auto",
|
|
210
192
|
children: /*#__PURE__*/_jsx(AppHeaderMainMenuMobile, {
|
|
211
193
|
action: action,
|
|
212
194
|
items: items.mainMenu,
|
|
213
195
|
getItemType: onItemType,
|
|
214
|
-
isAnon: isAnon
|
|
215
|
-
handleCloseMainMenu: () => setMobileMenuOpen(false)
|
|
216
|
-
})
|
|
217
|
-
}) : /*#__PURE__*/_jsx(StyledContentContainer, {
|
|
218
|
-
size: "small",
|
|
219
|
-
children: /*#__PURE__*/_jsx(AppHeaderMainMenuMobile, {
|
|
220
|
-
action: action,
|
|
221
|
-
items: items.mainMenu,
|
|
222
|
-
getItemType: onItemType,
|
|
223
|
-
isAnon: isAnon,
|
|
224
|
-
handleCloseMainMenu: () => setMobileMenuOpen(false)
|
|
196
|
+
isAnon: isAnon
|
|
225
197
|
})
|
|
226
198
|
})]
|
|
227
199
|
})
|
|
@@ -12,7 +12,8 @@ export const CompanyLinks = ({
|
|
|
12
12
|
onClick,
|
|
13
13
|
userGeo,
|
|
14
14
|
referralRockUrls,
|
|
15
|
-
isBusinessUser
|
|
15
|
+
isBusinessUser,
|
|
16
|
+
isLoggedIn
|
|
16
17
|
}) => {
|
|
17
18
|
const community = /*#__PURE__*/_jsxs(Box, {
|
|
18
19
|
children: [/*#__PURE__*/_jsx(FooterHeading, {
|
|
@@ -196,8 +197,8 @@ export const CompanyLinks = ({
|
|
|
196
197
|
},
|
|
197
198
|
children: [/*#__PURE__*/_jsx(FooterHeading, {
|
|
198
199
|
children: "Support"
|
|
199
|
-
}), /*#__PURE__*/
|
|
200
|
-
children: /*#__PURE__*/_jsx(FooterLinkItem, {
|
|
200
|
+
}), /*#__PURE__*/_jsxs(FooterLinkItems, {
|
|
201
|
+
children: [/*#__PURE__*/_jsx(FooterLinkItem, {
|
|
201
202
|
children: /*#__PURE__*/_jsx(Anchor, {
|
|
202
203
|
href: "https://help.codecademy.com",
|
|
203
204
|
onClick: event => onClick({
|
|
@@ -208,7 +209,18 @@ export const CompanyLinks = ({
|
|
|
208
209
|
variant: "interface",
|
|
209
210
|
children: "Help Center"
|
|
210
211
|
})
|
|
211
|
-
})
|
|
212
|
+
}), isLoggedIn && /*#__PURE__*/_jsx(FooterLinkItem, {
|
|
213
|
+
children: /*#__PURE__*/_jsx(Anchor, {
|
|
214
|
+
href: "https://a.sprig.com/ZTFvMkttQTI0fnNpZDo4YzNkNDBiYS0zZDBmLTQyZDktOGQ3Yy00YzRhZWUxYzZkOGU=",
|
|
215
|
+
onClick: event => onClick({
|
|
216
|
+
event,
|
|
217
|
+
target: 'give_feedback'
|
|
218
|
+
}),
|
|
219
|
+
target: "_blank",
|
|
220
|
+
variant: "interface",
|
|
221
|
+
children: "Give feedback"
|
|
222
|
+
})
|
|
223
|
+
})]
|
|
212
224
|
})]
|
|
213
225
|
});
|
|
214
226
|
const logo = display => /*#__PURE__*/_jsx(Box, {
|
|
@@ -8,13 +8,14 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
8
8
|
const FooterNavLinksGrid = /*#__PURE__*/_styled(LayoutGrid, {
|
|
9
9
|
target: "e1f7ortw0",
|
|
10
10
|
label: "FooterNavLinksGrid"
|
|
11
|
-
})(theme.breakpoints.sm, "{padding:2rem 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11
|
+
})(theme.breakpoints.sm, "{padding:2rem 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9HbG9iYWxGb290ZXIvRm9vdGVyTmF2TGlua3MvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVU2QyIsImZpbGUiOiIuLi8uLi8uLi9zcmMvR2xvYmFsRm9vdGVyL0Zvb3Rlck5hdkxpbmtzL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbHVtbiwgTGF5b3V0R3JpZCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IHRoZW1lIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgQ2F0YWxvZ0xpbmtzIH0gZnJvbSAnLi9DYXRhbG9nTGlua3MnO1xuaW1wb3J0IHsgQ29tcGFueUxpbmtzLCBDb21wYW55TGlua3NQcm9wcyB9IGZyb20gJy4vQ29tcGFueUxpbmtzJztcblxuZXhwb3J0IHR5cGUgRm9vdGVyTmF2TGlua3NQcm9wcyA9IENvbXBhbnlMaW5rc1Byb3BzO1xuXG5jb25zdCBGb290ZXJOYXZMaW5rc0dyaWQgPSBzdHlsZWQoTGF5b3V0R3JpZClgXG4gICR7dGhlbWUuYnJlYWtwb2ludHMuc219IHtcbiAgICBwYWRkaW5nOiAycmVtIDA7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXJOYXZMaW5rczogUmVhY3QuRkM8Rm9vdGVyTmF2TGlua3NQcm9wcz4gPSAoe1xuICBoaWRlUHJpY2luZyxcbiAgb25DbGljayxcbiAgdXNlckdlbyxcbiAgcmVmZXJyYWxSb2NrVXJscyxcbiAgaXNCdXNpbmVzc1VzZXIsXG4gIGlzTG9nZ2VkSW4sXG59KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPEZvb3Rlck5hdkxpbmtzR3JpZD5cbiAgICAgIDxDb2x1bW4gc2l6ZT17eyBfOiAxMiwgbWQ6IDYgfX0+XG4gICAgICAgIDxDb21wYW55TGlua3NcbiAgICAgICAgICBoaWRlUHJpY2luZz17aGlkZVByaWNpbmd9XG4gICAgICAgICAgb25DbGljaz17b25DbGlja31cbiAgICAgICAgICB1c2VyR2VvPXt1c2VyR2VvfVxuICAgICAgICAgIHJlZmVycmFsUm9ja1VybHM9e3JlZmVycmFsUm9ja1VybHN9XG4gICAgICAgICAgaXNCdXNpbmVzc1VzZXI9e2lzQnVzaW5lc3NVc2VyfVxuICAgICAgICAgIGlzTG9nZ2VkSW49e2lzTG9nZ2VkSW59XG4gICAgICAgIC8+XG4gICAgICA8L0NvbHVtbj5cbiAgICAgIDxDb2x1bW4gc2l6ZT17eyBfOiAxMiwgbWQ6IDYgfX0+XG4gICAgICAgIDxDYXRhbG9nTGlua3Mgb25DbGljaz17b25DbGlja30gdXNlckdlbz17dXNlckdlb30gLz5cbiAgICAgIDwvQ29sdW1uPlxuICAgIDwvRm9vdGVyTmF2TGlua3NHcmlkPlxuICApO1xufTtcbiJdfQ== */"));
|
|
12
12
|
export const FooterNavLinks = ({
|
|
13
13
|
hidePricing,
|
|
14
14
|
onClick,
|
|
15
15
|
userGeo,
|
|
16
16
|
referralRockUrls,
|
|
17
|
-
isBusinessUser
|
|
17
|
+
isBusinessUser,
|
|
18
|
+
isLoggedIn
|
|
18
19
|
}) => {
|
|
19
20
|
return /*#__PURE__*/_jsxs(FooterNavLinksGrid, {
|
|
20
21
|
children: [/*#__PURE__*/_jsx(Column, {
|
|
@@ -27,7 +28,8 @@ export const FooterNavLinks = ({
|
|
|
27
28
|
onClick: onClick,
|
|
28
29
|
userGeo: userGeo,
|
|
29
30
|
referralRockUrls: referralRockUrls,
|
|
30
|
-
isBusinessUser: isBusinessUser
|
|
31
|
+
isBusinessUser: isBusinessUser,
|
|
32
|
+
isLoggedIn: isLoggedIn
|
|
31
33
|
})
|
|
32
34
|
}), /*#__PURE__*/_jsx(Column, {
|
|
33
35
|
size: {
|
|
@@ -8,7 +8,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
8
8
|
const FooterContainer = /*#__PURE__*/_styled("footer", {
|
|
9
9
|
target: "e1xir4o10",
|
|
10
10
|
label: "FooterContainer"
|
|
11
|
-
})("border-top:1px solid ", themed('colors.secondary'), ";@media print{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11
|
+
})("border-top:1px solid ", themed('colors.secondary'), ";@media print{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9HbG9iYWxGb290ZXIvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlDcUMiLCJmaWxlIjoiLi4vLi4vc3JjL0dsb2JhbEZvb3Rlci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250ZW50Q29udGFpbmVyIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQnO1xuaW1wb3J0IHsgdGhlbWVkIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgRm9vdGVyTGVnYWwgfSBmcm9tICcuL0Zvb3RlckxlZ2FsJztcbmltcG9ydCB7IEZvb3Rlck5hdkxpbmtzIH0gZnJvbSAnLi9Gb290ZXJOYXZMaW5rcyc7XG5pbXBvcnQgdHlwZSB7IFJlZmVycmFsUm9ja1VybHMgfSBmcm9tICcuL0Zvb3Rlck5hdkxpbmtzL1JlZmVycmFsUm9jay90eXBlcyc7XG5pbXBvcnQgeyBHbG9iYWxGb290ZXJDbGlja0hhbmRsZXIgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgR2xvYmFsRm9vdGVyUHJvcHMgPSB7XG4gIGNsYXNzTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogSGlkZSBwcmljaW5nIGRldGFpbHMsIHN1Y2ggYXMgZm9yIHJlbmRlcmluZyBpbiBhbiBhcHAgc3RvcmUgYXBwLlxuICAgKi9cbiAgaGlkZVByaWNpbmc/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBDYWxsZWQgd2hlbmV2ZXIgYSBsaW5rIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiBHbG9iYWxGb290ZXJDbGlja0hhbmRsZXI7XG5cbiAgLyoqXG4gICAqIENhbGxlZCB3aGVuIHRoZSB0ZXh0IGluIHRoZSBNYWRlSW4gY29tcG9uZW50IGlzIGNsaWNrZWRcbiAgICovXG4gIG9uTWFkZUluQ2xpY2s/OiAodGV4dDogc3RyaW5nKSA9PiB2b2lkO1xuICB1c2VyR2VvPzogc3RyaW5nO1xuICByZWZlcnJhbFJvY2tVcmxzPzogUmVmZXJyYWxSb2NrVXJscztcbiAgaXNCdXNpbmVzc1VzZXI/OiBib29sZWFuO1xuICBpc0xvZ2dlZEluPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEZvb3RlckNvbnRhaW5lciA9IHN0eWxlZC5mb290ZXJgXG4gIGJvcmRlci10b3A6IDFweCBzb2xpZCAke3RoZW1lZCgnY29sb3JzLnNlY29uZGFyeScpfTtcblxuICBAbWVkaWEgcHJpbnQge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBHbG9iYWxGb290ZXI6IFJlYWN0LkZDPEdsb2JhbEZvb3RlclByb3BzPiA9ICh7XG4gIGNsYXNzTmFtZSxcbiAgaGlkZVByaWNpbmcsXG4gIG9uQ2xpY2ssXG4gIG9uTWFkZUluQ2xpY2ssXG4gIHVzZXJHZW8sXG4gIHJlZmVycmFsUm9ja1VybHMsXG4gIGlzQnVzaW5lc3NVc2VyLFxuICBpc0xvZ2dlZEluLFxufSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxGb290ZXJDb250YWluZXIgY2xhc3NOYW1lPXtjbGFzc05hbWV9IHJvbGU9XCJjb250ZW50aW5mb1wiPlxuICAgICAgPENvbnRlbnRDb250YWluZXI+XG4gICAgICAgIDxGb290ZXJOYXZMaW5rc1xuICAgICAgICAgIGhpZGVQcmljaW5nPXtoaWRlUHJpY2luZ31cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIHVzZXJHZW89e3VzZXJHZW99XG4gICAgICAgICAgcmVmZXJyYWxSb2NrVXJscz17cmVmZXJyYWxSb2NrVXJsc31cbiAgICAgICAgICBpc0J1c2luZXNzVXNlcj17aXNCdXNpbmVzc1VzZXJ9XG4gICAgICAgICAgaXNMb2dnZWRJbj17aXNMb2dnZWRJbn1cbiAgICAgICAgLz5cbiAgICAgICAgPEZvb3RlckxlZ2FsIG9uQ2xpY2s9e29uQ2xpY2t9IG9uTWFkZUluQ2xpY2s9e29uTWFkZUluQ2xpY2t9IC8+XG4gICAgICA8L0NvbnRlbnRDb250YWluZXI+XG4gICAgPC9Gb290ZXJDb250YWluZXI+XG4gICk7XG59O1xuIl19 */"));
|
|
12
12
|
export const GlobalFooter = ({
|
|
13
13
|
className,
|
|
14
14
|
hidePricing,
|
|
@@ -16,7 +16,8 @@ export const GlobalFooter = ({
|
|
|
16
16
|
onMadeInClick,
|
|
17
17
|
userGeo,
|
|
18
18
|
referralRockUrls,
|
|
19
|
-
isBusinessUser
|
|
19
|
+
isBusinessUser,
|
|
20
|
+
isLoggedIn
|
|
20
21
|
}) => {
|
|
21
22
|
return /*#__PURE__*/_jsx(FooterContainer, {
|
|
22
23
|
className: className,
|
|
@@ -27,7 +28,8 @@ export const GlobalFooter = ({
|
|
|
27
28
|
onClick: onClick,
|
|
28
29
|
userGeo: userGeo,
|
|
29
30
|
referralRockUrls: referralRockUrls,
|
|
30
|
-
isBusinessUser: isBusinessUser
|
|
31
|
+
isBusinessUser: isBusinessUser,
|
|
32
|
+
isLoggedIn: isLoggedIn
|
|
31
33
|
}), /*#__PURE__*/_jsx(FooterLegal, {
|
|
32
34
|
onClick: onClick,
|
|
33
35
|
onMadeInClick: onMadeInClick
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Shimmer, Text } from '@codecademy/gamut';
|
|
2
|
-
import { AccountingCoinsIcon, ArrowThickCircleUpIcon, ArticleIcon, BookFlipPageIcon, BriefcaseIcon, CalendarIcon, CommunityIcon, EarthIcon, GearIcon, HouseEntranceIcon, MiniArrowRightIcon, NotebookIcon, OfficeBuildingDoubleIcon, OnlineClassStudentIcon, PersonIcon, PersonPonytailIcon, PieLineGraphIcon, SupportIcon } from '@codecademy/gamut-icons';
|
|
2
|
+
import { AccountingCoinsIcon, ArrowThickCircleUpIcon, ArticleIcon, BookFlipPageIcon, BriefcaseIcon, CalendarIcon, ChatIcon, CommunityIcon, EarthIcon, GearIcon, HouseEntranceIcon, MiniArrowRightIcon, NotebookIcon, OfficeBuildingDoubleIcon, OnlineClassStudentIcon, PersonIcon, PersonPonytailIcon, PieLineGraphIcon, SupportIcon } from '@codecademy/gamut-icons';
|
|
3
3
|
import { renderNewBadge } from '../lib/resourcesList';
|
|
4
4
|
import { formatEnterpriseUrl } from './urlHelpers';
|
|
5
5
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
@@ -248,6 +248,15 @@ const profileHelpCenter = {
|
|
|
248
248
|
text: 'Help Center',
|
|
249
249
|
type: 'link'
|
|
250
250
|
};
|
|
251
|
+
const profileFeedback = {
|
|
252
|
+
id: 'give_feedback',
|
|
253
|
+
icon: ChatIcon,
|
|
254
|
+
href: 'https://a.sprig.com/ZTFvMkttQTI0fnNpZDo4YzNkNDBiYS0zZDBmLTQyZDktOGQ3Yy00YzRhZWUxYzZkOGU=',
|
|
255
|
+
newTab: true,
|
|
256
|
+
trackingTarget: 'avatar_give_feedback',
|
|
257
|
+
text: 'Give Feedback',
|
|
258
|
+
type: 'link'
|
|
259
|
+
};
|
|
251
260
|
const profileAdmin = {
|
|
252
261
|
id: 'admin',
|
|
253
262
|
dataTestId: 'admin-link',
|
|
@@ -288,6 +297,7 @@ export const freeProfile = user => {
|
|
|
288
297
|
topSection.push(profileBusinessAccount);
|
|
289
298
|
}
|
|
290
299
|
topSection.push(profileHelpCenter);
|
|
300
|
+
topSection.push(profileFeedback);
|
|
291
301
|
const bottomSection = [profileLogOut];
|
|
292
302
|
const popover = [topSection, bottomSection];
|
|
293
303
|
return {
|
|
@@ -307,6 +317,7 @@ export const proProfile = user => {
|
|
|
307
317
|
}
|
|
308
318
|
topSection.push(profileMyHome);
|
|
309
319
|
topSection.push(profileHelpCenter);
|
|
320
|
+
topSection.push(profileFeedback);
|
|
310
321
|
const teamsAdminSection = [];
|
|
311
322
|
if (shouldShowBusinessDashboardLink(user)) {
|
|
312
323
|
teamsAdminSection.push(profileBusinessAccount);
|
|
@@ -2,7 +2,6 @@ import * as React from 'react';
|
|
|
2
2
|
import { AnonHeader, EnterpriseHeader, FreeHeader, LoadingHeader, ProHeader, SimpleBootcampHeader, SimpleHeader, TeamsHeader } from './types';
|
|
3
3
|
export * from './types';
|
|
4
4
|
export declare const LiveLearningHubContext: React.Context<boolean>;
|
|
5
|
-
export declare const GlobalNavRedesignContext: React.Context<boolean>;
|
|
6
5
|
export declare const RevampedBlpExperimentContext: React.Context<boolean>;
|
|
7
6
|
export type GlobalHeaderProps = AnonHeader | FreeHeader | ProHeader | EnterpriseHeader | TeamsHeader | LoadingHeader | SimpleHeader | SimpleBootcampHeader;
|
|
8
7
|
export declare const GlobalHeader: React.FC<GlobalHeaderProps>;
|
|
@@ -8,7 +8,6 @@ import { anonDefaultHeaderItems, anonDefaultMobileHeaderItems, anonLandingHeader
|
|
|
8
8
|
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
|
-
export const GlobalNavRedesignContext = /*#__PURE__*/React.createContext(false);
|
|
12
11
|
export const RevampedBlpExperimentContext = /*#__PURE__*/React.createContext(false);
|
|
13
12
|
|
|
14
13
|
// Overloading getAppHeaderItems function to return different types based on mobile parameter
|
|
@@ -130,56 +129,52 @@ export const GlobalHeader = props => {
|
|
|
130
129
|
return 'default';
|
|
131
130
|
}, [props.type])
|
|
132
131
|
},
|
|
133
|
-
children: /*#__PURE__*/_jsx(
|
|
134
|
-
value: !!props.
|
|
135
|
-
children: /*#__PURE__*/_jsx(
|
|
136
|
-
value:
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
,
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
hideRightMenuButton: props.type === 'simple' || props.type === 'loading',
|
|
180
|
-
navigationMenuFormattedLabel: props?.localizedLabels?.navigationMenuFormattedLabel
|
|
181
|
-
}), props.children]
|
|
182
|
-
})
|
|
132
|
+
children: /*#__PURE__*/_jsx(RevampedBlpExperimentContext.Provider, {
|
|
133
|
+
value: !!props.isInRevampedBlpExperimentVariant,
|
|
134
|
+
children: /*#__PURE__*/_jsx(GlobalHeaderItemClickContext.Provider, {
|
|
135
|
+
value: {
|
|
136
|
+
globalHeaderItemClick: combinedAction
|
|
137
|
+
},
|
|
138
|
+
children: /*#__PURE__*/_jsx(GlobalHeaderDynamicDataContext.Provider, {
|
|
139
|
+
value: useMemo(() => ({
|
|
140
|
+
globalHeaderDynamicData: dynamicData ?? null
|
|
141
|
+
}), [dynamicData]),
|
|
142
|
+
children: /*#__PURE__*/_jsxs(Box, {
|
|
143
|
+
as: "header",
|
|
144
|
+
position: "sticky",
|
|
145
|
+
top: 0,
|
|
146
|
+
zIndex: theme.elements.headerZ,
|
|
147
|
+
overflow: {
|
|
148
|
+
_: 'hidden',
|
|
149
|
+
sm: 'visible'
|
|
150
|
+
} // Prevent tooltip overflow on mobile
|
|
151
|
+
,
|
|
152
|
+
children: [/*#__PURE__*/_jsx(AppHeader, {
|
|
153
|
+
action: combinedAction,
|
|
154
|
+
items: getAppHeaderItems(props, false, dynamicDataLoading ?? false),
|
|
155
|
+
search: props.search,
|
|
156
|
+
...(props.type === 'anon' ? {
|
|
157
|
+
redirectParam: props.redirectParam
|
|
158
|
+
} : hideNotification ? {} : {
|
|
159
|
+
notifications: props.notifications
|
|
160
|
+
}),
|
|
161
|
+
hideRightButtonDefaults: hideNotification,
|
|
162
|
+
isTeams: props.type === 'teams',
|
|
163
|
+
type: hideNotification ? 'enterprise' : 'standard'
|
|
164
|
+
}), /*#__PURE__*/_jsx(AppHeaderMobile, {
|
|
165
|
+
action: combinedAction,
|
|
166
|
+
items: getAppHeaderItems(props, true, dynamicDataLoading ?? false),
|
|
167
|
+
...(props.type === 'anon' || hideNotification ? {} : {
|
|
168
|
+
notifications: props.notifications
|
|
169
|
+
}),
|
|
170
|
+
search: props.search,
|
|
171
|
+
redirectParam: props.type === 'anon' ? props.redirectParam : undefined,
|
|
172
|
+
isEnterprise: props.type === 'enterprise',
|
|
173
|
+
isAnon: props.type === 'anon',
|
|
174
|
+
isSimple: props.type === 'simple',
|
|
175
|
+
hideRightMenuButton: props.type === 'simple' || props.type === 'loading',
|
|
176
|
+
navigationMenuFormattedLabel: props?.localizedLabels?.navigationMenuFormattedLabel
|
|
177
|
+
}), props.children]
|
|
183
178
|
})
|
|
184
179
|
})
|
|
185
180
|
})
|
|
@@ -31,7 +31,6 @@ interface BaseHeader extends WithChildrenProp, AppHeaderAction {
|
|
|
31
31
|
hideEnterpriseHeader?: boolean;
|
|
32
32
|
localizedLabels?: localizedLabels;
|
|
33
33
|
search: AppHeaderSearch;
|
|
34
|
-
displayGlobalNavRedesign?: boolean;
|
|
35
34
|
isInRevampedBlpExperimentVariant?: boolean;
|
|
36
35
|
dynamicData?: GlobalHeaderDynamicData | null;
|
|
37
36
|
dynamicDataLoading?: boolean;
|