@codecademy/brand 3.33.1-alpha.ebe5725ec8.0 → 3.34.0-alpha.9f8abe28c4.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.
@@ -41,17 +41,17 @@ function MobileImageItemDefaults({
41
41
  const MobileImageItem = /*#__PURE__*/_styled(MobileImageItemDefaults, {
42
42
  target: "e1am55214",
43
43
  label: "MobileImageItem"
44
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAoCwB","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/live-learning\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Live Learning\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */");
44
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAoCwB","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/bootcamps\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Bootcamps\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */");
45
45
  const MobileImageLink = /*#__PURE__*/_styled(MobileImageLinkDefaults, {
46
46
  target: "e1am55213",
47
47
  label: "MobileImageLink"
48
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAsCwB","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/live-learning\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Live Learning\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */");
48
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAsCwB","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/bootcamps\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Bootcamps\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */");
49
49
  const CatalogLinksContainer = /*#__PURE__*/_styled("div", {
50
50
  target: "e1am55212",
51
51
  label: "CatalogLinksContainer"
52
52
  })("border-top:1px solid ", themed('colors.navy'), ";margin-top:2rem;", theme.breakpoints.sm, "{padding-top:2rem;}", theme.breakpoints.md, "{border-left:1px solid ", ({
53
53
  theme
54
- }) => theme.colors.navy, ";border-top:none;margin-left:0;margin-top:0;padding-left:2rem;padding-top:0;}", theme.breakpoints.lg, "{padding-left:4rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAwCwC","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/live-learning\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Live Learning\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */"));
54
+ }) => theme.colors.navy, ";border-top:none;margin-left:0;margin-top:0;padding-left:2rem;padding-top:0;}", theme.breakpoints.lg, "{padding-left:4rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAwCwC","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/bootcamps\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Bootcamps\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */"));
55
55
  const CatalogLinkArea = /*#__PURE__*/_styled(FooterLinkItems, {
56
56
  target: "e1am55211",
57
57
  label: "CatalogLinkArea"
@@ -63,7 +63,7 @@ const CatalogLinkArea = /*#__PURE__*/_styled(FooterLinkItems, {
63
63
  }
64
64
  }
65
65
  }
66
- }), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AA8D2E","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/live-learning\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Live Learning\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */"));
66
+ }), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AA8D2E","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/bootcamps\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Bootcamps\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */"));
67
67
  const CatalogFooterLinkItem = /*#__PURE__*/_styled(FooterLinkItem, {
68
68
  target: "e1am55210",
69
69
  label: "CatalogFooterLinkItem"
@@ -72,7 +72,7 @@ const CatalogFooterLinkItem = /*#__PURE__*/_styled(FooterLinkItem, {
72
72
  styles: "margin:0.25rem 0"
73
73
  } : {
74
74
  name: "vo4ymn",
75
- styles: "margin:0.25rem 0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAuEoD","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/live-learning\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Live Learning\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */",
75
+ styles: "margin:0.25rem 0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx"],"names":[],"mappings":"AAuEoD","file":"../../../src/GlobalFooter/FooterNavLinks/CatalogLinks.tsx","sourcesContent":["import { Anchor, Box, BoxProps, Column, LayoutGrid } from '@codecademy/gamut';\nimport { theme, themed, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\n\nimport { FooterHeading } from '../FooterHeading';\nimport { FooterLinkItem, FooterLinkItems } from '../FooterLinks';\nimport { GlobalFooterClickHandler } from '../types';\nimport downloadOnTheAppStore from './assets/download-on-the-app-store.svg';\nimport getItOnGooglePlay from './assets/get-it-on-google-play.png';\n\nconst defaultWidth = {\n  _: '50%',\n  md: '90%',\n};\n\nfunction MobileImageLinkDefaults({\n  display = 'inline-block',\n  variant = 'interface',\n  width = defaultWidth,\n  ...props\n}: React.ComponentProps<typeof Anchor>) {\n  return (\n    <Anchor width={width} display={display} variant={variant} {...props} />\n  );\n}\n\nfunction MobileImageItemDefaults({\n  as = 'li',\n  display = 'inline-block',\n  my = 8,\n  ...props\n}: React.ComponentProps<typeof Box>) {\n  return <Box as={as} display={display} my={my} {...props} />;\n}\n\nconst MobileImageItem = styled(MobileImageItemDefaults)();\n\nconst MobileImageLink = styled(MobileImageLinkDefaults)();\n\nconst CatalogLinksContainer = styled.div`\n  border-top: 1px solid ${themed('colors.navy')};\n  margin-top: 2rem;\n\n  ${theme.breakpoints.sm} {\n    padding-top: 2rem;\n  }\n\n  ${theme.breakpoints.md} {\n    border-left: 1px solid ${({ theme }) => theme.colors.navy};\n    border-top: none;\n    margin-left: 0;\n    margin-top: 0;\n    padding-left: 2rem;\n    padding-top: 0;\n  }\n\n  ${theme.breakpoints.lg} {\n    padding-left: 4rem;\n  }\n`;\n\nconst CatalogLinkArea = styled(FooterLinkItems)<{ variant?: 'fullHeight' }>`\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  margin-bottom: 1rem;\n\n  ${variant({ variants: { fullHeight: { maxHeight: { md: 'none' } } } })}\n`;\n\nconst CatalogFooterLinkItem = styled(FooterLinkItem)`\n  margin: 0.25rem 0;\n`;\n\nconst languages = [\n  ['bash', 'Bash'],\n  ['c', 'C'],\n  ['c-plus-plus', 'C++'],\n  ['c-sharp', 'C#'],\n  ['go', 'Go'],\n  ['html-css', 'HTML & CSS'],\n  ['java', 'Java'],\n  ['javascript', 'JavaScript'],\n  ['kotlin', 'Kotlin'],\n  ['php', 'PHP'],\n  ['python', 'Python'],\n  ['r', 'R'],\n  ['ruby', 'Ruby'],\n  ['sql', 'SQL'],\n  ['swift', 'Swift'],\n];\n\nconst subjects = [\n  ['artificial-intelligence', 'AI'],\n  ['cloud-computing', 'Cloud computing'],\n  ['code-foundations', 'Code foundations'],\n  ['computer-science', 'Computer science'],\n  ['cybersecurity', 'Cybersecurity'],\n  ['data-analytics', 'Data analytics'],\n  ['data-science', 'Data science'],\n  ['data-visualization', 'Data visualization'],\n  ['developer-tools', 'Developer tools'],\n  ['devops', 'DevOps'],\n  ['game-development', 'Game development'],\n  ['information-technology', 'IT'],\n  ['machine-learning', 'Machine learning'],\n  ['math', 'Math'],\n  ['mobile-development', 'Mobile development'],\n  ['web-design', 'Web design'],\n  ['web-development', 'Web development'],\n];\n\nexport type CatalogLinksProps = {\n  onClick: GlobalFooterClickHandler;\n  userGeo?: string;\n};\n\nexport const CatalogLinks: React.FC<CatalogLinksProps> = ({ onClick }) => {\n  const languagesList = (\n    <Box>\n      <FooterHeading>Languages</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {languages.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/language/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const subjectsList = (\n    <Box>\n      <FooterHeading>Subjects</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        {subjects.map(([slug, text]) => (\n          <CatalogFooterLinkItem key={slug}>\n            <Anchor\n              href={`/catalog/subject/${slug}`}\n              onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n                onClick({ event, target: slug })\n              }\n              variant=\"interface\"\n              whiteSpace=\"nowrap\"\n            >\n              {text}\n            </Anchor>\n          </CatalogFooterLinkItem>\n        ))}\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const careerBuildingList = (\n    <Box>\n      <FooterHeading>Career building</FooterHeading>\n      <CatalogLinkArea variant=\"fullHeight\">\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'catalog' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career paths\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/career-center\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'career_services' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Career Center\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/interview-prep\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'interview_prep' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Interview prep\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/pages/pro-certifications\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'pro_certifications' })\n            }\n            variant=\"interface\"\n            whiteSpace=\"nowrap\"\n          >\n            Professional certification\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/bootcamps\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'bootcamps' })\n            }\n            variant=\"interface\"\n          >\n            Bootcamps\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem aria-hidden>—</CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/all\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'fullCatalog' })\n            }\n            variant=\"interface\"\n          >\n            Full catalog\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"/catalog/subject/beta\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'betaContent' })\n            }\n            variant=\"interface\"\n          >\n            Beta content\n          </Anchor>\n        </CatalogFooterLinkItem>\n        <CatalogFooterLinkItem>\n          <Anchor\n            href=\"https://trello.com/b/vAgDXtT6/codecademy-releases-roadmap\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'roadmap' })\n            }\n            variant=\"interface\"\n          >\n            Roadmap\n          </Anchor>\n        </CatalogFooterLinkItem>\n      </CatalogLinkArea>\n    </Box>\n  );\n\n  const appStoreLinks = (display: BoxProps['display']) => (\n    <Box display={display}>\n      <FooterHeading>Mobile</FooterHeading>\n      <FooterLinkItems display=\"flex\" flexDirection=\"column\">\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://itunes.apple.com/us/app/codecademy-go/id1376029326\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'apple_store' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Download on the App Store\"\n              height=\"calc(40px + 1rem)\"\n              src={downloadOnTheAppStore}\n              width=\"calc(120px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n        <MobileImageItem>\n          <MobileImageLink\n            href=\"https://play.google.com/store/apps/details?id=com.ryzac.codecademygo\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement>) =>\n              onClick({ event, target: 'google_play' })\n            }\n            target=\"_blank\"\n            rel=\"noopener\"\n          >\n            <img\n              alt=\"Get it on Google Play\"\n              height=\"calc(40px + 1rem)\"\n              src={getItOnGooglePlay}\n              width=\"calc(133px + 1.5rem)\"\n            />\n          </MobileImageLink>\n        </MobileImageItem>\n      </FooterLinkItems>\n    </Box>\n  );\n\n  // Footer items change placement depending on screen size\n  return (\n    <CatalogLinksContainer>\n      <LayoutGrid columnGap={24}>\n        <Column size={{ _: 6, sm: 4 }}>{subjectsList}</Column>\n        <Column size={{ _: 6, sm: 4 }}>{languagesList}</Column>\n        <Column size={{ _: 6, sm: 4 }} gridTemplateRows=\"min-content\">\n          {careerBuildingList}\n          {/* desktop/tablet */}\n          {appStoreLinks({ _: 'none', sm: 'unset' })}\n        </Column>\n        <Column size={6} display={{ _: 'block', sm: 'none' }}>\n          {/* mobile */}\n          {appStoreLinks({ _: 'unset', sm: 'none' })}\n        </Column>\n      </LayoutGrid>\n    </CatalogLinksContainer>\n  );\n};\n"]} */",
76
76
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
77
77
  });
78
78
  const languages = [['bash', 'Bash'], ['c', 'C'], ['c-plus-plus', 'C++'], ['c-sharp', 'C#'], ['go', 'Go'], ['html-css', 'HTML & CSS'], ['java', 'Java'], ['javascript', 'JavaScript'], ['kotlin', 'Kotlin'], ['php', 'PHP'], ['python', 'Python'], ['r', 'R'], ['ruby', 'Ruby'], ['sql', 'SQL'], ['swift', 'Swift']];
@@ -169,13 +169,13 @@ export const CatalogLinks = ({
169
169
  })
170
170
  }), /*#__PURE__*/_jsx(CatalogFooterLinkItem, {
171
171
  children: /*#__PURE__*/_jsx(Anchor, {
172
- href: "/live-learning",
172
+ href: "/bootcamps",
173
173
  onClick: event => onClick({
174
174
  event,
175
175
  target: 'bootcamps'
176
176
  }),
177
177
  variant: "interface",
178
- children: "Live Learning"
178
+ children: "Bootcamps"
179
179
  })
180
180
  }), /*#__PURE__*/_jsx(CatalogFooterLinkItem, {
181
181
  "aria-hidden": true,
@@ -4,7 +4,7 @@ export declare const loading: AppHeaderRenderElementItem;
4
4
  export declare const logo: AppHeaderLogoItem;
5
5
  export declare const enterpriseLogo: (user: User, removeAnchorLink?: boolean) => AppHeaderLogoItem;
6
6
  export declare const myHome: AppHeaderLinkItem;
7
- export declare const liveLearningHub: AppHeaderLinkItem;
7
+ export declare const bootcampsHub: AppHeaderLinkItem;
8
8
  export declare const myPercipioHome: (user: User, customTitle?: string) => AppHeaderLinkItem;
9
9
  export declare const catalogDropdown: (hideCareerPaths?: boolean) => AppHeaderCatalogDropdownItem;
10
10
  export declare const resourcesDropdown: () => AppHeaderResourcesDropdownItem;
@@ -50,13 +50,13 @@ export const myHome = {
50
50
  trackingTarget: 'topnav_home',
51
51
  type: 'link'
52
52
  };
53
- export const liveLearningHub = {
54
- dataTestId: 'header-live-learning-hub',
53
+ export const bootcampsHub = {
54
+ dataTestId: 'header-bootcamps-hub',
55
55
  icon: OnlineClassStudentIcon,
56
- id: 'live-learning-hub',
57
- text: 'Live Learning',
58
- href: '/live-learning',
59
- trackingTarget: 'topnav_live_learning_hub',
56
+ id: 'bootcamps-hub',
57
+ text: 'Bootcamps',
58
+ href: '/bootcamps',
59
+ trackingTarget: 'topnav_bootcamps_hub',
60
60
  type: 'link',
61
61
  badge: renderNewBadge(4)
62
62
  };
@@ -1,4 +1,4 @@
1
- import { addPayment, bootcampCta, businessSolutions, catalogDropdown, communityDropdown, enterpriseLogo, freeProfile, liveLearningHub, loading, login, logo, myHome, myPercipioHome, pricingDropdown, proProfile, requestTeamsDemo, resourcesDropdown, signUp, signUpTextButton, simpleResourcesDropdown, tryProForFree, unpausePro, upgradePlan, upgradeToPro } from './GlobalHeaderItems';
1
+ import { addPayment, bootcampCta, bootcampsHub, businessSolutions, catalogDropdown, communityDropdown, enterpriseLogo, freeProfile, loading, login, logo, myHome, myPercipioHome, pricingDropdown, proProfile, requestTeamsDemo, resourcesDropdown, signUp, signUpTextButton, simpleResourcesDropdown, tryProForFree, unpausePro, upgradePlan, upgradeToPro } from './GlobalHeaderItems';
2
2
  const isBusinessPage = () => {
3
3
  if (typeof window === 'undefined') return false;
4
4
  return window.location.pathname === '/business' || window.location.pathname === '/business/pricing';
@@ -22,7 +22,7 @@ const anonHeaderItems = ({
22
22
  ...logo,
23
23
  checkMini: true
24
24
  };
25
- const leftItems = [specialLogo, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), liveLearningHub, businessSolutions];
25
+ const leftItems = [specialLogo, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), bootcampsHub, businessSolutions];
26
26
  const rightItems = [];
27
27
  if (isBusinessPage()) {
28
28
  if (renderSignUp) {
@@ -72,7 +72,7 @@ const anonMobileHeaderItems = ({
72
72
  rightItems.push(signUp);
73
73
  }
74
74
  }
75
- const mainMenuItems = [catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), liveLearningHub, businessSolutions];
75
+ const mainMenuItems = [catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), bootcampsHub, businessSolutions];
76
76
  return {
77
77
  left: leftItems,
78
78
  right: rightItems,
@@ -192,7 +192,7 @@ export const freeHeaderItems = ({
192
192
  ...logo,
193
193
  checkMini: true
194
194
  };
195
- const leftItems = [specialLogo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), liveLearningHub, businessSolutions];
195
+ const leftItems = [specialLogo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), bootcampsHub, businessSolutions];
196
196
  const upgradeButton = upgradeToPro(user.proCheckoutUrl);
197
197
  const rightItems = [];
198
198
  rightItems.push(freeProfile(user));
@@ -214,7 +214,7 @@ export const freeMobileHeaderItems = ({
214
214
  const leftItems = [specialLogo];
215
215
  const rightItems = [];
216
216
  const upgradeButton = upgradeToPro(user.proCheckoutUrl);
217
- const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), liveLearningHub, businessSolutions, freeProfile(user), user.showProUpgrade ? upgradeButton : tryProForFree(user.proCheckoutUrl)];
217
+ const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), bootcampsHub, businessSolutions, freeProfile(user), user.showProUpgrade ? upgradeButton : tryProForFree(user.proCheckoutUrl)];
218
218
  return {
219
219
  left: leftItems,
220
220
  right: rightItems,
@@ -240,7 +240,7 @@ export const enterpriseHeaderItems = ({
240
240
  export const proHeaderItems = ({
241
241
  user
242
242
  }) => {
243
- const leftItems = [logo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(user.isPlusUser ? [upgradePlan] : []), liveLearningHub, businessSolutions];
243
+ const leftItems = [logo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(user.isPlusUser ? [upgradePlan] : []), bootcampsHub, businessSolutions];
244
244
  const rightItems = [];
245
245
  rightItems.push(proProfile(user));
246
246
  if (user.isPaused) {
@@ -254,7 +254,7 @@ export const proHeaderItems = ({
254
254
  export const teamsHeaderItems = ({
255
255
  user
256
256
  }) => {
257
- const leftItems = [logo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), liveLearningHub];
257
+ const leftItems = [logo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), bootcampsHub];
258
258
  const rightItems = [];
259
259
  if (user.isAccountManager && user.inBusinessTrial && !user.hasBusinessSubscription) {
260
260
  rightItems.push(addPayment);
@@ -289,7 +289,7 @@ export const proMobileHeaderItems = ({
289
289
  }) => {
290
290
  const leftItems = [logo];
291
291
  const rightItems = [];
292
- const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(user.isPlusUser ? [upgradePlan] : []), liveLearningHub, businessSolutions, proProfile(user)];
292
+ const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(user.isPlusUser ? [upgradePlan] : []), bootcampsHub, businessSolutions, proProfile(user)];
293
293
  if (user.isPaused) {
294
294
  mainMenuItems.push(unpausePro);
295
295
  }
@@ -304,7 +304,7 @@ export const teamsMobileHeaderItems = ({
304
304
  }) => {
305
305
  const leftItems = [logo];
306
306
  const rightItems = [];
307
- const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), liveLearningHub, proProfile(user)];
307
+ const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), bootcampsHub, proProfile(user)];
308
308
  if (user.isAccountManager && user.inBusinessTrial && !user.hasBusinessSubscription) {
309
309
  mainMenuItems.push(addPayment);
310
310
  }
@@ -41,7 +41,7 @@ export const liveLearningHubItems = {
41
41
  description: 'Build skills faster through live learning with expert instructors.',
42
42
  data: [{
43
43
  id: 'bootcamps',
44
- href: '/live-learning',
44
+ href: '/bootcamps',
45
45
  text: 'Bootcamps',
46
46
  description: 'Learn live from industry experts.',
47
47
  trackingTarget: 'topnav_catalog_live_learning_bootcamps',
@@ -66,7 +66,7 @@ export const liveLearningNavPanelItems = {
66
66
  description: 'Build skills faster through live, instructor-led sessions. Get real-time feedback, stay motivated, and deepen your understanding with expert guidance.',
67
67
  data: [{
68
68
  id: 'bootcamps',
69
- href: '/live-learning',
69
+ href: '/bootcamps',
70
70
  text: 'Bootcamps',
71
71
  description: 'Join live virtual bootcamps that span multiple weeks and help you build real-world, in-demand skills. Led by experts, each bootcamp includes instructor support, community, professional mentorship—and comes with Codecademy Pro access.',
72
72
  trackingTarget: 'topnav_catalog_live_learning_bootcamps',
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@codecademy/brand",
3
3
  "description": "Brand component library for Codecademy",
4
- "version": "3.33.1-alpha.ebe5725ec8.0",
4
+ "version": "3.34.0-alpha.9f8abe28c4.0",
5
5
  "author": "Codecademy Engineering <dev@codecademy.com>",
6
6
  "dependencies": {
7
7
  "@emotion/is-prop-valid": "^1.2.1",