@codecademy/brand 3.9.0-alpha.fdab2109d0.0 → 3.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.js +38 -22
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.d.ts +3 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.js +129 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderFeatureCard/index.js +11 -7
- package/dist/AppHeader/AppHeaderElements/AppHeaderLinkSections/index.js +0 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/NavPanels.js +26 -42
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts.js +74 -56
- package/dist/AppHeader/AppHeaderElements/AppHeaderSkillTile/index.d.ts +6 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSkillTile/index.js +65 -0
- package/dist/PricingSection/PricingCard/index.d.ts +1 -5
- package/dist/PricingSection/PricingCard/index.js +6 -8
- package/dist/PricingSection/ProductCTA.d.ts +1 -5
- package/dist/PricingSection/ProductCTA.js +1 -27
- package/dist/PricingSection/Products.d.ts +0 -4
- package/dist/PricingSection/Products.js +3 -6
- package/dist/PricingSection/index.d.ts +0 -4
- package/dist/PricingSection/index.js +2 -4
- package/package.json +1 -1
|
@@ -5,11 +5,12 @@ import { LevelIcon } from '@codecademy/gamut-icons';
|
|
|
5
5
|
import { theme } from '@codecademy/gamut-styles';
|
|
6
6
|
import { CourseDifficulty } from '../../../ContentGroupBaseCard/types';
|
|
7
7
|
import { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';
|
|
8
|
-
import { liveLearningHubItems
|
|
8
|
+
import { liveLearningHubItems } from '../../../lib/catalogList';
|
|
9
9
|
import { AppHeaderDietCard } from '../AppHeaderDietCard';
|
|
10
10
|
import { useAppHeaderSectionContext } from '../AppHeaderSection/AppHeaderSectionContext';
|
|
11
11
|
import { PanelLayout } from '../AppHeaderSection/PanelLayout';
|
|
12
|
-
import {
|
|
12
|
+
import { SkillTile } from '../AppHeaderSkillTile';
|
|
13
|
+
import { CERTIFICATION_PROVIDERS, popularLanguages, popularSubjects } from './consts';
|
|
13
14
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
14
15
|
export const CourseTopicsPanel = () => {
|
|
15
16
|
const {
|
|
@@ -31,7 +32,7 @@ export const CourseTopicsPanel = () => {
|
|
|
31
32
|
children: "Take the quiz"
|
|
32
33
|
})]
|
|
33
34
|
});
|
|
34
|
-
return /*#__PURE__*/
|
|
35
|
+
return /*#__PURE__*/_jsxs(PanelLayout, {
|
|
35
36
|
heading: "Course topics",
|
|
36
37
|
description: description,
|
|
37
38
|
linkItem: {
|
|
@@ -41,7 +42,12 @@ export const CourseTopicsPanel = () => {
|
|
|
41
42
|
trackingTarget: 'catalog-header-view-all-courses',
|
|
42
43
|
id: 'view-all-courses'
|
|
43
44
|
},
|
|
44
|
-
children: /*#__PURE__*/_jsx(
|
|
45
|
+
children: [/*#__PURE__*/_jsx(Text, {
|
|
46
|
+
variant: "p-large",
|
|
47
|
+
fontWeight: 700,
|
|
48
|
+
as: "h3",
|
|
49
|
+
children: "Popular languages"
|
|
50
|
+
}), /*#__PURE__*/_jsx(GridBox, {
|
|
45
51
|
gridTemplateColumns: {
|
|
46
52
|
_: '1fr',
|
|
47
53
|
xs: '1fr 1fr',
|
|
@@ -51,23 +57,33 @@ export const CourseTopicsPanel = () => {
|
|
|
51
57
|
pl: 0,
|
|
52
58
|
as: "ul",
|
|
53
59
|
listStyle: "none",
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
60
|
+
mb: 24,
|
|
61
|
+
children: popularLanguages.map(item => /*#__PURE__*/_jsx("li", {
|
|
62
|
+
children: /*#__PURE__*/_jsx(SkillTile, {
|
|
63
|
+
item: item
|
|
64
|
+
})
|
|
65
|
+
}, item.id))
|
|
66
|
+
}), /*#__PURE__*/_jsx(Text, {
|
|
67
|
+
variant: "p-large",
|
|
68
|
+
fontWeight: 700,
|
|
69
|
+
as: "h3",
|
|
70
|
+
children: "Popular subjects"
|
|
71
|
+
}), /*#__PURE__*/_jsx(GridBox, {
|
|
72
|
+
gridTemplateColumns: {
|
|
73
|
+
_: '1fr',
|
|
74
|
+
xs: '1fr 1fr',
|
|
75
|
+
md: '1fr 1fr 1fr'
|
|
76
|
+
},
|
|
77
|
+
gap: 8,
|
|
78
|
+
pl: 0,
|
|
79
|
+
as: "ul",
|
|
80
|
+
listStyle: "none",
|
|
81
|
+
children: popularSubjects.map(item => /*#__PURE__*/_jsx("li", {
|
|
82
|
+
children: /*#__PURE__*/_jsx(SkillTile, {
|
|
83
|
+
item: item
|
|
84
|
+
})
|
|
85
|
+
}, item.id))
|
|
86
|
+
})]
|
|
71
87
|
});
|
|
72
88
|
};
|
|
73
89
|
export const DietCardGrid = ({
|
|
@@ -141,7 +157,7 @@ const GrayscaleToColorHoverCard = /*#__PURE__*/_styled(Card, {
|
|
|
141
157
|
label: "GrayscaleToColorHoverCard"
|
|
142
158
|
})("filter:grayscale(1);img{filter:", ({
|
|
143
159
|
overrideImgFilters
|
|
144
|
-
}) => overrideImgFilters ? 'contrast(5)' : 'brightness(0.25)', ";}transition:filter 0.2s ease-in-out;&:hover,a:focus &{filter:grayscale(0);img{filter:brightness(1);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.tsx"],"names":[],"mappings":"AAoKE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.tsx","sourcesContent":["/* eslint-disable react/no-array-index-key */ // can be removed once we add dynamic data\nimport { Anchor, Box, Card, FlexBox, GridBox, Text } from '@codecademy/gamut';\nimport { LevelIcon } from '@codecademy/gamut-icons';\nimport { theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { CourseDifficulty } from '../../../ContentGroupBaseCard/types';\nimport { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';\nimport { liveLearningHubItems, topLanguages } from '../../../lib/catalogList';\nimport { AppHeaderDietCard } from '../AppHeaderDietCard';\nimport { useAppHeaderSectionContext } from '../AppHeaderSection/AppHeaderSectionContext';\nimport { PanelLayout } from '../AppHeaderSection/PanelLayout';\nimport { CERTIFICATION_PROVIDERS } from './consts';\n\nexport const CourseTopicsPanel = () => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const { tabIndex } = useAppHeaderSectionContext();\n\n  const description = (\n    <>\n      Explore free or paid courses in a wide variety of topics. With something\n      for every skill level, it&apos;s easy to find a course that fits your\n      goals. Not sure where to start? &nbsp;\n      <Anchor\n        tabIndex={tabIndex}\n        href=\"/welcome/find-a-course\"\n        onClick={(event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) =>\n          globalHeaderItemClick(event, {\n            type: 'link',\n            href: '/welcome/find-a-course',\n            text: 'Take the quiz',\n            id: 'take-the-quiz',\n          })\n        }\n      >\n        Take the quiz\n      </Anchor>\n    </>\n  );\n\n  return (\n    <PanelLayout\n      heading=\"Course topics\"\n      description={description}\n      linkItem={{\n        type: 'link',\n        href: '/catalog?type=course',\n        text: 'View all courses',\n        trackingTarget: 'catalog-header-view-all-courses',\n        id: 'view-all-courses',\n      }}\n    >\n      <GridBox\n        gridTemplateColumns={{ _: '1fr', xs: '1fr 1fr', md: '1fr 1fr 1fr' }}\n        gap={8}\n        pl={0}\n        as=\"ul\"\n        listStyle=\"none\"\n      >\n        {topLanguages.map((item) => (\n          <Anchor\n            variant=\"interface\"\n            href={item.href}\n            onClick={(event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) =>\n              globalHeaderItemClick(event, item)\n            }\n            tabIndex={tabIndex}\n            key={`${item.id}`}\n          >\n            <FlexBox\n              height={48}\n              px={16}\n              py={8}\n              borderRadius=\"md\"\n              border={1}\n              borderColor=\"border-tertiary\"\n              alignItems=\"center\"\n              key={`${item.id}`}\n            >\n              {item.text}\n              {item.badge}\n            </FlexBox>\n          </Anchor>\n        ))}\n      </GridBox>\n    </PanelLayout>\n  );\n};\n\nexport const DietCardGrid = ({ children }: { children: React.ReactNode }) => {\n  return (\n    <GridBox\n      gridTemplateColumns={{ _: '1fr', sm: '1fr 1fr', md: 'repeat(3, 1fr)' }}\n      gap={16}\n    >\n      {children}\n    </GridBox>\n  );\n};\n\nexport const CareerPathCard = () => {\n  const { tabIndex } = useAppHeaderSectionContext();\n  return (\n    <AppHeaderDietCard\n      title=\"Full-Stack Engineer\"\n      hours={150}\n      icon={<LevelIcon />}\n      difficulty={CourseDifficulty.Beginner}\n      tabIndex={tabIndex}\n    />\n  );\n};\n\nexport const CareerPathsPanel = () => {\n  return (\n    <PanelLayout\n      heading=\"Popular career paths\"\n      description=\"Choose your career and we'll teach you the skills to get job-ready. Each Career Path contains a curated list of lessons, quizzes, videos, and projects to help you learn and practice real-world skills.\"\n      linkItem={{\n        type: 'link',\n        href: '/catalog?type=career-path',\n        text: 'View all career paths',\n        trackingTarget: 'catalog-header-view-all-career-paths',\n        id: 'view-all-career-paths',\n      }}\n    >\n      <DietCardGrid>\n        {Array.from({ length: 6 }).map((_, index) => (\n          <CareerPathCard key={`${index}-card`} />\n        ))}\n      </DietCardGrid>\n    </PanelLayout>\n  );\n};\n\nexport const SkillPathsPanel = () => {\n  return (\n    <PanelLayout\n      heading=\"Skill paths\"\n      description=\"Build a specific skill fast with a short, curated path.\"\n      linkItem={{\n        type: 'link',\n        href: '/catalog?type=skill-path',\n        text: 'View all skill paths',\n        trackingTarget: 'catalog-header-view-all-skill-paths',\n        id: 'view-all-skill-paths',\n      }}\n    >\n      <DietCardGrid>\n        {Array.from({ length: 6 }).map((_, index) => (\n          <CareerPathCard key={`${index}-card`} />\n        ))}\n      </DietCardGrid>\n    </PanelLayout>\n  );\n};\n\nexport const getCertificationProviderLogoUrl = (fileName: string) =>\n  `https://static-assets.codecademy.com/assets/certification-provider-logos/catalog-dropdown/v1/${fileName}`;\n\nconst Image = Box.withComponent('img');\n\nconst GrayscaleToColorHoverCard = styled(Card)<{\n  overrideImgFilters?: boolean;\n}>`\n  filter: grayscale(1);\n  img {\n    filter: ${({ overrideImgFilters }) =>\n      overrideImgFilters ? 'contrast(5)' : 'brightness(0.25)'};\n  }\n  transition: filter 0.2s ease-in-out;\n  &:hover,\n  a:focus & {\n    filter: grayscale(0);\n    img {\n      filter: brightness(1);\n    }\n  }\n`;\n\nconst ProviderChip = ({\n  name,\n  href,\n  imgSrc,\n  tabIndex,\n}: {\n  name: string;\n  href: string;\n  imgSrc: string;\n  tabIndex: number;\n}) => {\n  return (\n    <Anchor\n      href={href}\n      variant=\"interface\"\n      key={name}\n      tabIndex={tabIndex}\n      width=\"100%\"\n      height=\"100%\"\n      display=\"block\"\n    >\n      <GrayscaleToColorHoverCard\n        borderColor=\"border-tertiary\"\n        borderRadius=\"lg\"\n        isInteractive\n        width=\"100%\"\n        height=\"100%\"\n        p={8}\n        overrideImgFilters={name.toLowerCase() === 'kubernetes'}\n      >\n        <Image src={imgSrc} alt={name} display=\"block\" m=\"auto\" height={52} />\n      </GrayscaleToColorHoverCard>\n    </Anchor>\n  );\n};\n\nexport const CertificationPathsPanel = () => {\n  const { tabIndex } = useAppHeaderSectionContext();\n  return (\n    <PanelLayout\n      heading=\"Certification paths\"\n      description=\"Prepare for top industry certifications with a guided path. Each one includes expert-reviewed lessons, hands-on projects, and practice tests to help you pass the exam.\"\n      linkItem={{\n        type: 'link',\n        href: '/catalog/certification-prep',\n        text: 'Explore all certification paths',\n        trackingTarget: 'catalog-header-view-all-certification-paths',\n        id: 'view-all-certification-paths',\n      }}\n    >\n      <Text as=\"h3\" fontSize={18} fontWeight=\"bold\">\n        Providers\n      </Text>\n      <GridBox\n        gridTemplateColumns={{\n          _: '1fr',\n          xs: 'repeat(2, 1fr)',\n          sm: 'repeat(3, 1fr)',\n          md: 'repeat(4, 1fr)',\n        }}\n        gap={16}\n        width=\"100%\"\n        as=\"ul\"\n        listStyle=\"none\"\n        p={0}\n        m={0}\n      >\n        {CERTIFICATION_PROVIDERS.map(({ name, logoUrl, hubType }) => (\n          <Box as=\"li\" key={name} width=\"100%\">\n            <ProviderChip\n              name={name}\n              href={\n                hubType === 'subhub'\n                  ? `/search?query=${name} certifications`\n                  : `/catalog/certification-prep?provider=${name.toLowerCase()}`\n              }\n              imgSrc={logoUrl}\n              tabIndex={tabIndex}\n            />\n          </Box>\n        ))}\n      </GridBox>\n    </PanelLayout>\n  );\n};\n\nexport const LiveLearningPanel = () => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  return (\n    <PanelLayout\n      heading=\"Live learning\"\n      description=\"Explore the live learning opportunities available in our courses\"\n      linkItem={{\n        type: 'link',\n        href: '/live-learning',\n        text: 'Learn more about live learning',\n        trackingTarget: 'catalog-header-learn-more-about-live-learning',\n        id: 'learn-more-about-live-learning',\n      }}\n    >\n      <GridBox\n        gridTemplateColumns={{ _: '1fr', md: 'repeat(2, 1fr)' }}\n        gap={16}\n      >\n        {liveLearningHubItems.data.map((item) => (\n          <Anchor\n            href={item.href}\n            key={item.id}\n            variant=\"interface\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) =>\n              globalHeaderItemClick(event, item)\n            }\n          >\n            <Card isInteractive p={0}>\n              <Box\n                height=\"225px\"\n                width=\"100%\"\n                background={theme.colors['gray-300']}\n              />\n              <FlexBox flexDirection=\"column\" gap={8} p={16}>\n                <Text variant=\"title-xs\">{item.text}</Text>\n                {'description' in item && <Text>{item.description}</Text>}\n              </FlexBox>\n            </Card>\n          </Anchor>\n        ))}\n      </GridBox>\n    </PanelLayout>\n  );\n};\n"]} */"));
|
|
160
|
+
}) => overrideImgFilters ? 'contrast(5)' : 'brightness(0.25)', ";}transition:filter 0.2s ease-in-out;&:hover,a:focus &{filter:grayscale(0);img{filter:brightness(1);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.tsx"],"names":[],"mappings":"AA0KE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.tsx","sourcesContent":["/* eslint-disable react/no-array-index-key */ // can be removed once we add dynamic data\nimport { Anchor, Box, Card, FlexBox, GridBox, Text } from '@codecademy/gamut';\nimport { LevelIcon } from '@codecademy/gamut-icons';\nimport { theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { CourseDifficulty } from '../../../ContentGroupBaseCard/types';\nimport { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';\nimport { liveLearningHubItems } from '../../../lib/catalogList';\nimport { AppHeaderDietCard } from '../AppHeaderDietCard';\nimport { useAppHeaderSectionContext } from '../AppHeaderSection/AppHeaderSectionContext';\nimport { PanelLayout } from '../AppHeaderSection/PanelLayout';\nimport { SkillTile } from '../AppHeaderSkillTile';\nimport {\n  CERTIFICATION_PROVIDERS,\n  popularLanguages,\n  popularSubjects,\n} from './consts';\n\nexport const CourseTopicsPanel = () => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const { tabIndex } = useAppHeaderSectionContext();\n\n  const description = (\n    <>\n      Explore free or paid courses in a wide variety of topics. With something\n      for every skill level, it&apos;s easy to find a course that fits your\n      goals. Not sure where to start? &nbsp;\n      <Anchor\n        tabIndex={tabIndex}\n        href=\"/welcome/find-a-course\"\n        onClick={(event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) =>\n          globalHeaderItemClick(event, {\n            type: 'link',\n            href: '/welcome/find-a-course',\n            text: 'Take the quiz',\n            id: 'take-the-quiz',\n          })\n        }\n      >\n        Take the quiz\n      </Anchor>\n    </>\n  );\n\n  return (\n    <PanelLayout\n      heading=\"Course topics\"\n      description={description}\n      linkItem={{\n        type: 'link',\n        href: '/catalog?type=course',\n        text: 'View all courses',\n        trackingTarget: 'catalog-header-view-all-courses',\n        id: 'view-all-courses',\n      }}\n    >\n      <Text variant=\"p-large\" fontWeight={700} as=\"h3\">\n        Popular languages\n      </Text>\n      <GridBox\n        gridTemplateColumns={{ _: '1fr', xs: '1fr 1fr', md: '1fr 1fr 1fr' }}\n        gap={8}\n        pl={0}\n        as=\"ul\"\n        listStyle=\"none\"\n        mb={24}\n      >\n        {popularLanguages.map((item) => (\n          <li key={item.id}>\n            <SkillTile item={item} />\n          </li>\n        ))}\n      </GridBox>\n\n      <Text variant=\"p-large\" fontWeight={700} as=\"h3\">\n        Popular subjects\n      </Text>\n      <GridBox\n        gridTemplateColumns={{ _: '1fr', xs: '1fr 1fr', md: '1fr 1fr 1fr' }}\n        gap={8}\n        pl={0}\n        as=\"ul\"\n        listStyle=\"none\"\n      >\n        {popularSubjects.map((item) => (\n          <li key={item.id}>\n            <SkillTile item={item} />\n          </li>\n        ))}\n      </GridBox>\n    </PanelLayout>\n  );\n};\n\nexport const DietCardGrid = ({ children }: { children: React.ReactNode }) => {\n  return (\n    <GridBox\n      gridTemplateColumns={{ _: '1fr', sm: '1fr 1fr', md: 'repeat(3, 1fr)' }}\n      gap={16}\n    >\n      {children}\n    </GridBox>\n  );\n};\n\nexport const CareerPathCard = () => {\n  const { tabIndex } = useAppHeaderSectionContext();\n  return (\n    <AppHeaderDietCard\n      title=\"Full-Stack Engineer\"\n      hours={150}\n      icon={<LevelIcon />}\n      difficulty={CourseDifficulty.Beginner}\n      tabIndex={tabIndex}\n    />\n  );\n};\n\nexport const CareerPathsPanel = () => {\n  return (\n    <PanelLayout\n      heading=\"Popular career paths\"\n      description=\"Choose your career and we'll teach you the skills to get job-ready. Each Career Path contains a curated list of lessons, quizzes, videos, and projects to help you learn and practice real-world skills.\"\n      linkItem={{\n        type: 'link',\n        href: '/catalog?type=career-path',\n        text: 'View all career paths',\n        trackingTarget: 'catalog-header-view-all-career-paths',\n        id: 'view-all-career-paths',\n      }}\n    >\n      <DietCardGrid>\n        {Array.from({ length: 6 }).map((_, index) => (\n          <CareerPathCard key={`${index}-card`} />\n        ))}\n      </DietCardGrid>\n    </PanelLayout>\n  );\n};\n\nexport const SkillPathsPanel = () => {\n  return (\n    <PanelLayout\n      heading=\"Skill paths\"\n      description=\"Build a specific skill fast with a short, curated path.\"\n      linkItem={{\n        type: 'link',\n        href: '/catalog?type=skill-path',\n        text: 'View all skill paths',\n        trackingTarget: 'catalog-header-view-all-skill-paths',\n        id: 'view-all-skill-paths',\n      }}\n    >\n      <DietCardGrid>\n        {Array.from({ length: 6 }).map((_, index) => (\n          <CareerPathCard key={`${index}-card`} />\n        ))}\n      </DietCardGrid>\n    </PanelLayout>\n  );\n};\n\nexport const getCertificationProviderLogoUrl = (fileName: string) =>\n  `https://static-assets.codecademy.com/assets/certification-provider-logos/catalog-dropdown/v1/${fileName}`;\n\nconst Image = Box.withComponent('img');\n\nconst GrayscaleToColorHoverCard = styled(Card)<{\n  overrideImgFilters?: boolean;\n}>`\n  filter: grayscale(1);\n  img {\n    filter: ${({ overrideImgFilters }) =>\n      overrideImgFilters ? 'contrast(5)' : 'brightness(0.25)'};\n  }\n  transition: filter 0.2s ease-in-out;\n  &:hover,\n  a:focus & {\n    filter: grayscale(0);\n    img {\n      filter: brightness(1);\n    }\n  }\n`;\n\nconst ProviderChip = ({\n  name,\n  href,\n  imgSrc,\n  tabIndex,\n}: {\n  name: string;\n  href: string;\n  imgSrc: string;\n  tabIndex: number;\n}) => {\n  return (\n    <Anchor\n      href={href}\n      variant=\"interface\"\n      key={name}\n      tabIndex={tabIndex}\n      width=\"100%\"\n      height=\"100%\"\n      display=\"block\"\n    >\n      <GrayscaleToColorHoverCard\n        borderColor=\"border-tertiary\"\n        borderRadius=\"lg\"\n        isInteractive\n        width=\"100%\"\n        height=\"100%\"\n        p={8}\n        overrideImgFilters={name.toLowerCase() === 'kubernetes'}\n      >\n        <Image src={imgSrc} alt={name} display=\"block\" m=\"auto\" height={52} />\n      </GrayscaleToColorHoverCard>\n    </Anchor>\n  );\n};\n\nexport const CertificationPathsPanel = () => {\n  const { tabIndex } = useAppHeaderSectionContext();\n  return (\n    <PanelLayout\n      heading=\"Certification paths\"\n      description=\"Prepare for top industry certifications with a guided path. Each one includes expert-reviewed lessons, hands-on projects, and practice tests to help you pass the exam.\"\n      linkItem={{\n        type: 'link',\n        href: '/catalog/certification-prep',\n        text: 'Explore all certification paths',\n        trackingTarget: 'catalog-header-view-all-certification-paths',\n        id: 'view-all-certification-paths',\n      }}\n    >\n      <Text as=\"h3\" fontSize={18} fontWeight=\"bold\">\n        Providers\n      </Text>\n      <GridBox\n        gridTemplateColumns={{\n          _: '1fr',\n          xs: 'repeat(2, 1fr)',\n          sm: 'repeat(3, 1fr)',\n          md: 'repeat(4, 1fr)',\n        }}\n        gap={16}\n        width=\"100%\"\n        as=\"ul\"\n        listStyle=\"none\"\n        p={0}\n        m={0}\n      >\n        {CERTIFICATION_PROVIDERS.map(({ name, logoUrl, hubType }) => (\n          <Box as=\"li\" key={name} width=\"100%\">\n            <ProviderChip\n              name={name}\n              href={\n                hubType === 'subhub'\n                  ? `/search?query=${name} certifications`\n                  : `/catalog/certification-prep?provider=${name.toLowerCase()}`\n              }\n              imgSrc={logoUrl}\n              tabIndex={tabIndex}\n            />\n          </Box>\n        ))}\n      </GridBox>\n    </PanelLayout>\n  );\n};\n\nexport const LiveLearningPanel = () => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  return (\n    <PanelLayout\n      heading=\"Live learning\"\n      description=\"Explore the live learning opportunities available in our courses\"\n      linkItem={{\n        type: 'link',\n        href: '/live-learning',\n        text: 'Learn more about live learning',\n        trackingTarget: 'catalog-header-learn-more-about-live-learning',\n        id: 'learn-more-about-live-learning',\n      }}\n    >\n      <GridBox\n        gridTemplateColumns={{ _: '1fr', md: 'repeat(2, 1fr)' }}\n        gap={16}\n      >\n        {liveLearningHubItems.data.map((item) => (\n          <Anchor\n            href={item.href}\n            key={item.id}\n            variant=\"interface\"\n            onClick={(event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) =>\n              globalHeaderItemClick(event, item)\n            }\n          >\n            <Card isInteractive p={0}>\n              <Box\n                height=\"225px\"\n                width=\"100%\"\n                background={theme.colors['gray-300']}\n              />\n              <FlexBox flexDirection=\"column\" gap={8} p={16}>\n                <Text variant=\"title-xs\">{item.text}</Text>\n                {'description' in item && <Text>{item.description}</Text>}\n              </FlexBox>\n            </Card>\n          </Anchor>\n        ))}\n      </GridBox>\n    </PanelLayout>\n  );\n};\n"]} */"));
|
|
145
161
|
const ProviderChip = ({
|
|
146
162
|
name,
|
|
147
163
|
href,
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { AppHeaderCatalogDropdownItem } from '../../shared';
|
|
2
|
+
import { AppHeaderCatalogDropdownItem, AppHeaderLinkItem } from '../../shared';
|
|
3
3
|
export type NavSectionConfig = {
|
|
4
4
|
item: AppHeaderCatalogDropdownItem;
|
|
5
5
|
panel: React.ComponentType<{
|
|
@@ -16,3 +16,5 @@ export declare const CERTIFICATION_PROVIDERS: {
|
|
|
16
16
|
logoUrl: string;
|
|
17
17
|
hubType: string;
|
|
18
18
|
}[];
|
|
19
|
+
export declare const popularLanguages: AppHeaderLinkItem[];
|
|
20
|
+
export declare const popularSubjects: AppHeaderLinkItem[];
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { BookLibraryIcon, BriefcaseIcon, OnlineClassStudentIcon, ProfessionalCertificateIcon, StudyBookIcon } from '@codecademy/gamut-icons';
|
|
1
|
+
import { ArtificialIntelligenceIcon, BookLibraryIcon, BriefcaseIcon, CIcon, CloudComputingIcon, CPlusIcon, CSharpIcon, CybersecurityIcon, DataEngineeringIcon, DataScienceIcon, GrowthIcon, HtmlCssIcon, JavaIcon, JavascriptIcon, OnlineClassStudentIcon, PhpIcon, ProfessionalCertificateIcon, ProgrammingBrowserIcon, PythonIcon, SqlIcon, StudyBookIcon, WebDesignIcon, WebDevelopmentIcon } from '@codecademy/gamut-icons';
|
|
2
2
|
import { CareerPathsPanel, CertificationPathsPanel, CourseTopicsPanel, getCertificationProviderLogoUrl, LiveLearningPanel, SkillPathsPanel } from './NavPanels';
|
|
3
3
|
export const CATALOG_NAV_SECTIONS = [{
|
|
4
4
|
item: {
|
|
@@ -98,4 +98,132 @@ export const CERTIFICATION_PROVIDERS = [{
|
|
|
98
98
|
name: 'Project Management Institute',
|
|
99
99
|
logoUrl: getCertificationProviderLogoUrl('pmi.svg'),
|
|
100
100
|
hubType: 'certification-prep'
|
|
101
|
+
}];
|
|
102
|
+
export const popularLanguages = [{
|
|
103
|
+
id: 'python',
|
|
104
|
+
href: '/catalog/language/python',
|
|
105
|
+
trackingTarget: 'topnav_catalog_skill_python',
|
|
106
|
+
text: 'Python',
|
|
107
|
+
type: 'link',
|
|
108
|
+
icon: PythonIcon
|
|
109
|
+
}, {
|
|
110
|
+
id: 'javascript',
|
|
111
|
+
href: '/catalog/language/javascript',
|
|
112
|
+
trackingTarget: 'topnav_catalog_skill_javascript',
|
|
113
|
+
text: 'JavaScript',
|
|
114
|
+
type: 'link',
|
|
115
|
+
icon: JavascriptIcon
|
|
116
|
+
}, {
|
|
117
|
+
id: 'html-css',
|
|
118
|
+
href: '/catalog/language/html-css',
|
|
119
|
+
trackingTarget: 'topnav_catalog_skill_html-css',
|
|
120
|
+
text: 'HTML & CSS',
|
|
121
|
+
type: 'link',
|
|
122
|
+
icon: HtmlCssIcon
|
|
123
|
+
}, {
|
|
124
|
+
id: 'c-sharp',
|
|
125
|
+
href: '/catalog/language/c-sharp',
|
|
126
|
+
trackingTarget: 'topnav_catalog_skill_c-sharp',
|
|
127
|
+
text: 'C#',
|
|
128
|
+
type: 'link',
|
|
129
|
+
icon: CSharpIcon
|
|
130
|
+
}, {
|
|
131
|
+
id: 'c-plus-plus',
|
|
132
|
+
href: '/catalog/language/c-plus-plus',
|
|
133
|
+
trackingTarget: 'topnav_catalog_skill_c-plus-plus',
|
|
134
|
+
text: 'C++',
|
|
135
|
+
type: 'link',
|
|
136
|
+
icon: CPlusIcon
|
|
137
|
+
}, {
|
|
138
|
+
id: 'c',
|
|
139
|
+
href: '/catalog/language/c',
|
|
140
|
+
trackingTarget: 'topnav_catalog_skill_c',
|
|
141
|
+
text: 'C',
|
|
142
|
+
type: 'link',
|
|
143
|
+
icon: CIcon
|
|
144
|
+
}, {
|
|
145
|
+
id: 'php',
|
|
146
|
+
href: '/catalog/language/php',
|
|
147
|
+
trackingTarget: 'topnav_catalog_skill_php',
|
|
148
|
+
text: 'PHP',
|
|
149
|
+
type: 'link',
|
|
150
|
+
icon: PhpIcon
|
|
151
|
+
}, {
|
|
152
|
+
id: 'java',
|
|
153
|
+
href: '/catalog/language/java',
|
|
154
|
+
trackingTarget: 'topnav_catalog_skill_java',
|
|
155
|
+
text: 'Java',
|
|
156
|
+
type: 'link',
|
|
157
|
+
icon: JavaIcon
|
|
158
|
+
}, {
|
|
159
|
+
id: 'sql',
|
|
160
|
+
href: '/catalog/language/sql',
|
|
161
|
+
trackingTarget: 'topnav_catalog_skill_sql',
|
|
162
|
+
text: 'SQL',
|
|
163
|
+
type: 'link',
|
|
164
|
+
icon: SqlIcon
|
|
165
|
+
}];
|
|
166
|
+
export const popularSubjects = [{
|
|
167
|
+
id: 'artificial-intelligence',
|
|
168
|
+
href: '/catalog/subject/artificial-intelligence',
|
|
169
|
+
trackingTarget: 'topnav_catalog_skill_ai',
|
|
170
|
+
text: 'AI',
|
|
171
|
+
type: 'link',
|
|
172
|
+
icon: ArtificialIntelligenceIcon
|
|
173
|
+
}, {
|
|
174
|
+
id: 'it',
|
|
175
|
+
href: '/catalog/subject/information-technology',
|
|
176
|
+
trackingTarget: 'topnav_catalog_skill_it',
|
|
177
|
+
text: 'IT',
|
|
178
|
+
type: 'link',
|
|
179
|
+
icon: DataEngineeringIcon
|
|
180
|
+
}, {
|
|
181
|
+
id: 'cybersecurity',
|
|
182
|
+
href: '/catalog/subject/cybersecurity',
|
|
183
|
+
trackingTarget: 'topnav_catalog_skill_cybersecurity',
|
|
184
|
+
text: 'Cybersecurity',
|
|
185
|
+
type: 'link',
|
|
186
|
+
icon: CybersecurityIcon
|
|
187
|
+
}, {
|
|
188
|
+
id: 'cloud-computing',
|
|
189
|
+
href: '/catalog/subject/cloud-computing',
|
|
190
|
+
trackingTarget: 'topnav_catalog_skill_cloud-computing',
|
|
191
|
+
text: 'Cloud computing',
|
|
192
|
+
type: 'link',
|
|
193
|
+
icon: CloudComputingIcon
|
|
194
|
+
}, {
|
|
195
|
+
id: 'web-development',
|
|
196
|
+
href: '/catalog/subject/web-development',
|
|
197
|
+
trackingTarget: 'topnav_catalog_skill_web_development',
|
|
198
|
+
text: 'Web development',
|
|
199
|
+
type: 'link',
|
|
200
|
+
icon: WebDevelopmentIcon
|
|
201
|
+
}, {
|
|
202
|
+
id: 'data-science',
|
|
203
|
+
href: '/catalog/subject/data-science',
|
|
204
|
+
trackingTarget: 'topnav_catalog_skill_data-science',
|
|
205
|
+
text: 'Data science',
|
|
206
|
+
type: 'link',
|
|
207
|
+
icon: DataScienceIcon
|
|
208
|
+
}, {
|
|
209
|
+
id: 'web-design',
|
|
210
|
+
href: '/catalog/subject/web-design',
|
|
211
|
+
trackingTarget: 'topnav_catalog_skill_web-design',
|
|
212
|
+
text: 'Web design',
|
|
213
|
+
type: 'link',
|
|
214
|
+
icon: WebDesignIcon
|
|
215
|
+
}, {
|
|
216
|
+
id: 'professional-skills',
|
|
217
|
+
href: '/catalog/subject/professional-skills',
|
|
218
|
+
trackingTarget: 'topnav_catalog_skill_professional-skills',
|
|
219
|
+
text: 'Professional skills',
|
|
220
|
+
type: 'link',
|
|
221
|
+
icon: GrowthIcon
|
|
222
|
+
}, {
|
|
223
|
+
id: 'code-foundations',
|
|
224
|
+
href: '/catalog/subject/code-foundations',
|
|
225
|
+
trackingTarget: 'topnav_catalog_skill_code-foundations',
|
|
226
|
+
text: 'Code foundations',
|
|
227
|
+
type: 'link',
|
|
228
|
+
icon: ProgrammingBrowserIcon
|
|
101
229
|
}];
|
|
@@ -10,13 +10,13 @@ const StyledCard = /*#__PURE__*/_styled(Card, {
|
|
|
10
10
|
theme
|
|
11
11
|
}) => theme.colors.primary, ";border-color:", ({
|
|
12
12
|
theme
|
|
13
|
-
}) => theme.colors.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyRmVhdHVyZUNhcmQvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU8rQiIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlckZlYXR1cmVDYXJkL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IEdyaWREZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IHRoZW1lIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQXBwSGVhZGVyQ2FyZEl0ZW0gfSBmcm9tICcuLi9BcHBIZWFkZXJSZXNvdXJjZXNEcm9wZG93bi9jb25zdHMnO1xuXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkKENhcmQpYFxuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeX07XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5fTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEFwcEhlYWRlckZlYXR1cmVDYXJkID0gKHsgaXRlbSB9OiB7IGl0ZW06IEFwcEhlYWRlckNhcmRJdGVtIH0pID0+
|
|
13
|
+
}) => theme.colors.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyRmVhdHVyZUNhcmQvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU8rQiIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlckZlYXR1cmVDYXJkL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IEdyaWREZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IHRoZW1lIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQXBwSGVhZGVyQ2FyZEl0ZW0gfSBmcm9tICcuLi9BcHBIZWFkZXJSZXNvdXJjZXNEcm9wZG93bi9jb25zdHMnO1xuXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkKENhcmQpYFxuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeX07XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5wcmltYXJ5fTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEFwcEhlYWRlckZlYXR1cmVDYXJkID0gKHsgaXRlbSB9OiB7IGl0ZW06IEFwcEhlYWRlckNhcmRJdGVtIH0pID0+IHtcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkQ2FyZFxuICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgcHg9ezE2fVxuICAgICAgcHk9ezI0fVxuICAgICAgYm9yZGVyUmFkaXVzPVwibGdcIlxuICAgICAgYm9yZGVyPXsxfVxuICAgICAgYm9yZGVyQ29sb3I9XCJib3JkZXItdGVydGlhcnlcIlxuICAgICAgZGlzcGxheT1cImZsZXhcIlxuICAgICAgYWxpZ25JdGVtcz1cImZsZXgtc3RhcnRcIlxuICAgICAgZmxleERpcmVjdGlvbj1cImNvbHVtblwiXG4gICAgICBoZWlnaHQ9XCIxMDAlXCJcbiAgICA+XG4gICAgICA8RmxleEJveCBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgZ2FwPXs4fT5cbiAgICAgICAgPEZsZXhCb3hcbiAgICAgICAgICBiYWNrZ3JvdW5kPXt0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ119XG4gICAgICAgICAgYm9yZGVyUmFkaXVzPVwibWRcIlxuICAgICAgICAgIHA9ezR9XG4gICAgICAgICAgaGVpZ2h0PXszMn1cbiAgICAgICAgICB3aWR0aD17MzJ9XG4gICAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgICAganVzdGlmeUNvbnRlbnQ9XCJjZW50ZXJcIlxuICAgICAgICA+XG4gICAgICAgICAge2l0ZW0uaWNvbn1cbiAgICAgICAgPC9GbGV4Qm94PlxuICAgICAgICA8VGV4dCB2YXJpYW50PVwicC1sYXJnZVwiIGZvbnRXZWlnaHQ9ezcwMH0gYXM9XCJoM1wiPlxuICAgICAgICAgIHtpdGVtLmxpbmtJdGVtLnRleHR9XG4gICAgICAgIDwvVGV4dD5cbiAgICAgIDwvRmxleEJveD5cbiAgICAgIDxCb3ggd2lkdGg9XCIxMDAlXCI+XG4gICAgICAgIDxHcmlkRGVuc2UgaGVpZ2h0PXs0fSAvPlxuICAgICAgPC9Cb3g+XG4gICAgICA8VGV4dCB2YXJpYW50PVwicC1zbWFsbFwiPntpdGVtLmRlc2NyaXB0aW9ufTwvVGV4dD5cbiAgICA8L1N0eWxlZENhcmQ+XG4gICk7XG59O1xuIl19 */"));
|
|
14
14
|
export const AppHeaderFeatureCard = ({
|
|
15
15
|
item
|
|
16
16
|
}) => {
|
|
17
17
|
return /*#__PURE__*/_jsxs(StyledCard, {
|
|
18
18
|
isInteractive: true,
|
|
19
|
-
px:
|
|
19
|
+
px: 16,
|
|
20
20
|
py: 24,
|
|
21
21
|
borderRadius: "lg",
|
|
22
22
|
border: 1,
|
|
@@ -28,14 +28,19 @@ export const AppHeaderFeatureCard = ({
|
|
|
28
28
|
children: [/*#__PURE__*/_jsxs(FlexBox, {
|
|
29
29
|
alignItems: "center",
|
|
30
30
|
gap: 8,
|
|
31
|
-
children: [/*#__PURE__*/_jsx(
|
|
31
|
+
children: [/*#__PURE__*/_jsx(FlexBox, {
|
|
32
32
|
background: theme.colors['navy-200'],
|
|
33
33
|
borderRadius: "md",
|
|
34
34
|
p: 4,
|
|
35
|
-
height:
|
|
35
|
+
height: 32,
|
|
36
|
+
width: 32,
|
|
37
|
+
alignItems: "center",
|
|
38
|
+
justifyContent: "center",
|
|
36
39
|
children: item.icon
|
|
37
40
|
}), /*#__PURE__*/_jsx(Text, {
|
|
38
|
-
variant: "
|
|
41
|
+
variant: "p-large",
|
|
42
|
+
fontWeight: 700,
|
|
43
|
+
as: "h3",
|
|
39
44
|
children: item.linkItem.text
|
|
40
45
|
})]
|
|
41
46
|
}), /*#__PURE__*/_jsx(Box, {
|
|
@@ -44,8 +49,7 @@ export const AppHeaderFeatureCard = ({
|
|
|
44
49
|
height: 4
|
|
45
50
|
})
|
|
46
51
|
}), /*#__PURE__*/_jsx(Text, {
|
|
47
|
-
variant: "p-
|
|
48
|
-
fontSize: 14,
|
|
52
|
+
variant: "p-small",
|
|
49
53
|
children: item.description
|
|
50
54
|
})]
|
|
51
55
|
});
|
|
File without changes
|
|
@@ -1,31 +1,29 @@
|
|
|
1
|
-
import { Anchor, Box,
|
|
1
|
+
import { Anchor, Box, GridBox } from '@codecademy/gamut';
|
|
2
2
|
import { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';
|
|
3
3
|
import { useAppHeaderDropdownContext } from '../AppHeaderDropdownProvider';
|
|
4
4
|
import { AppHeaderFeatureCard } from '../AppHeaderFeatureCard';
|
|
5
5
|
import { useAppHeaderSectionContext } from '../AppHeaderSection/AppHeaderSectionContext';
|
|
6
6
|
import { PanelLayout } from '../AppHeaderSection/PanelLayout';
|
|
7
|
+
import { SkillTile } from '../AppHeaderSkillTile';
|
|
7
8
|
import { docsLinks, inspirationLinks, learningToolsLinks, practiceToolsLinks } from './consts';
|
|
8
9
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
9
10
|
export const DocsPanel = () => {
|
|
10
11
|
const {
|
|
11
12
|
globalHeaderItemClick
|
|
12
13
|
} = useGlobalHeaderItemClick();
|
|
13
|
-
const {
|
|
14
|
-
handleClose
|
|
15
|
-
} = useAppHeaderDropdownContext();
|
|
16
14
|
const {
|
|
17
15
|
tabIndex
|
|
18
16
|
} = useAppHeaderSectionContext();
|
|
19
17
|
const description = /*#__PURE__*/_jsxs(_Fragment, {
|
|
20
18
|
children: [/*#__PURE__*/_jsx(Box, {
|
|
21
19
|
mb: 8,
|
|
22
|
-
children: "
|
|
20
|
+
children: "Definitions and guides to help you understand programming languages, frameworks, and concepts. Built and maintained by the coding community."
|
|
23
21
|
}), "Interested in helping build it?", ' ', /*#__PURE__*/_jsx(Anchor, {
|
|
24
22
|
tabIndex: tabIndex,
|
|
25
|
-
href: "/
|
|
23
|
+
href: "/pages/contribute-docs",
|
|
26
24
|
onClick: event => globalHeaderItemClick(event, {
|
|
27
25
|
type: 'link',
|
|
28
|
-
href: '/
|
|
26
|
+
href: '/pages/contribute-docs',
|
|
29
27
|
text: 'Contribute to Docs',
|
|
30
28
|
id: 'contribute-to-docs'
|
|
31
29
|
}),
|
|
@@ -46,32 +44,17 @@ export const DocsPanel = () => {
|
|
|
46
44
|
gridTemplateColumns: {
|
|
47
45
|
_: '1fr',
|
|
48
46
|
xs: '1fr 1fr',
|
|
49
|
-
|
|
47
|
+
md: '1fr 1fr 1fr'
|
|
50
48
|
},
|
|
51
49
|
gap: 8,
|
|
52
50
|
pl: 0,
|
|
53
51
|
as: "ul",
|
|
54
52
|
listStyle: "none",
|
|
55
|
-
children: docsLinks.map(item => /*#__PURE__*/_jsx(
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
handleClose();
|
|
61
|
-
},
|
|
62
|
-
tabIndex: tabIndex,
|
|
63
|
-
as: "li",
|
|
64
|
-
children: /*#__PURE__*/_jsxs(FlexBox, {
|
|
65
|
-
height: 48,
|
|
66
|
-
px: 16,
|
|
67
|
-
py: 8,
|
|
68
|
-
borderRadius: "md",
|
|
69
|
-
border: 1,
|
|
70
|
-
borderColor: "border-tertiary",
|
|
71
|
-
alignItems: "center",
|
|
72
|
-
children: [item.text, item.badge]
|
|
73
|
-
}, `${item.id}`)
|
|
74
|
-
}, `${item.id}`))
|
|
53
|
+
children: docsLinks.map(item => /*#__PURE__*/_jsx("li", {
|
|
54
|
+
children: /*#__PURE__*/_jsx(SkillTile, {
|
|
55
|
+
item: item
|
|
56
|
+
})
|
|
57
|
+
}, item.id))
|
|
75
58
|
})
|
|
76
59
|
});
|
|
77
60
|
};
|
|
@@ -117,28 +100,29 @@ export const FeatureCardPanel = ({
|
|
|
117
100
|
return /*#__PURE__*/_jsx(GridBox, {
|
|
118
101
|
gridTemplateColumns: {
|
|
119
102
|
_: '1fr',
|
|
120
|
-
|
|
103
|
+
sm: '1fr 1fr'
|
|
121
104
|
},
|
|
122
105
|
gridTemplateRows: {
|
|
123
106
|
_: '1fr',
|
|
124
|
-
|
|
107
|
+
sm: '1fr 1fr'
|
|
125
108
|
},
|
|
126
109
|
gap: 16,
|
|
127
110
|
pl: 0,
|
|
128
111
|
as: "ul",
|
|
129
112
|
listStyle: "none",
|
|
130
|
-
children: links.map(item => /*#__PURE__*/_jsx(
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
113
|
+
children: links.map(item => /*#__PURE__*/_jsx("li", {
|
|
114
|
+
children: /*#__PURE__*/_jsx(Anchor, {
|
|
115
|
+
variant: "interface",
|
|
116
|
+
href: item.linkItem.href,
|
|
117
|
+
onClick: event => {
|
|
118
|
+
globalHeaderItemClick(event, item.linkItem);
|
|
119
|
+
handleClose();
|
|
120
|
+
},
|
|
121
|
+
tabIndex: tabIndex,
|
|
122
|
+
height: "100%",
|
|
123
|
+
children: /*#__PURE__*/_jsx(AppHeaderFeatureCard, {
|
|
124
|
+
item: item
|
|
125
|
+
})
|
|
142
126
|
})
|
|
143
127
|
}, `${item.linkItem.id}`))
|
|
144
128
|
});
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ArticleIcon, BriefcaseIcon, BulbIcon, CommentsIcon, FileIcon, HammerWrenchIcon, InfoCircleIcon, NotebookIcon, ProjectsIcon, RulerTriangleIcon, SearchIcon, VideoPlayerMovieIcon } from '@codecademy/gamut-icons';
|
|
1
|
+
import { ArticleIcon, BriefcaseIcon, BulbIcon, CIcon, CommentsIcon, ComputerScienceIcon, CPlusIcon, FileIcon, GameDevelopmentIcon, GaugeDashboardIcon, GitIcon, GoIcon, HammerWrenchIcon, HtmlCssIcon, InfoCircleIcon, JavaIcon, JavascriptIcon, LearnIcon, MarkdownIcon, NotebookIcon, PeopleIcon, PhpIcon, ProgrammingBrowserIcon, ProjectsIcon, PythonIcon, ReactIcon, RulerTriangleIcon, SearchIcon, SqlIcon, SwiftIcon, TerminalIcon, TypescriptIcon, VideoPlayerMovieIcon } from '@codecademy/gamut-icons';
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { DocsPanel, InspirationPanel, LearningToolsPanel, PracticeToolsPanel } from './NavPanels';
|
|
4
4
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
@@ -44,109 +44,127 @@ export const docsLinks = [{
|
|
|
44
44
|
href: '/resources/docs/c',
|
|
45
45
|
trackingTarget: 'topnav_resources_docs_c',
|
|
46
46
|
text: 'C',
|
|
47
|
-
type: 'link'
|
|
47
|
+
type: 'link',
|
|
48
|
+
icon: CIcon
|
|
48
49
|
}, {
|
|
49
50
|
id: 'html',
|
|
50
51
|
href: '/resources/docs/html',
|
|
51
52
|
trackingTarget: 'topnav_resources_docs_html',
|
|
52
53
|
text: 'HTML',
|
|
53
|
-
type: 'link'
|
|
54
|
+
type: 'link',
|
|
55
|
+
icon: HtmlCssIcon
|
|
54
56
|
}, {
|
|
55
57
|
id: 'python',
|
|
56
58
|
href: '/resources/docs/python',
|
|
57
59
|
trackingTarget: 'topnav_resources_docs_python',
|
|
58
60
|
text: 'Python',
|
|
59
|
-
type: 'link'
|
|
61
|
+
type: 'link',
|
|
62
|
+
icon: PythonIcon
|
|
60
63
|
}, {
|
|
61
64
|
id: 'cpp',
|
|
62
65
|
href: '/resources/docs/cpp',
|
|
63
66
|
trackingTarget: 'topnav_resources_docs_cpp',
|
|
64
67
|
text: 'C++',
|
|
65
|
-
type: 'link'
|
|
68
|
+
type: 'link',
|
|
69
|
+
icon: CPlusIcon
|
|
66
70
|
}, {
|
|
67
71
|
id: 'java',
|
|
68
72
|
href: '/resources/docs/java',
|
|
69
73
|
trackingTarget: 'topnav_resources_docs_java',
|
|
70
74
|
text: 'Java',
|
|
71
|
-
type: 'link'
|
|
75
|
+
type: 'link',
|
|
76
|
+
icon: JavaIcon
|
|
72
77
|
}, {
|
|
73
78
|
id: 'react',
|
|
74
79
|
href: '/resources/docs/react',
|
|
75
80
|
trackingTarget: 'topnav_resources_docs_react',
|
|
76
81
|
text: 'React',
|
|
77
|
-
type: 'link'
|
|
82
|
+
type: 'link',
|
|
83
|
+
icon: ReactIcon
|
|
78
84
|
}, {
|
|
79
85
|
id: 'css',
|
|
80
86
|
href: '/resources/docs/css',
|
|
81
87
|
trackingTarget: 'topnav_resources_docs_css',
|
|
82
88
|
text: 'CSS',
|
|
83
|
-
type: 'link'
|
|
89
|
+
type: 'link',
|
|
90
|
+
icon: HtmlCssIcon
|
|
84
91
|
}, {
|
|
85
92
|
id: 'javascript',
|
|
86
93
|
href: '/resources/docs/javascript',
|
|
87
94
|
trackingTarget: 'topnav_resources_docs_javascript',
|
|
88
95
|
text: 'JavaScript',
|
|
89
|
-
type: 'link'
|
|
96
|
+
type: 'link',
|
|
97
|
+
icon: JavascriptIcon
|
|
90
98
|
}, {
|
|
91
99
|
id: 'sql',
|
|
92
100
|
href: '/resources/docs/sql',
|
|
93
101
|
trackingTarget: 'topnav_resources_docs_sql',
|
|
94
102
|
text: 'SQL',
|
|
95
|
-
type: 'link'
|
|
103
|
+
type: 'link',
|
|
104
|
+
icon: SqlIcon
|
|
96
105
|
}, {
|
|
97
106
|
id: 'git',
|
|
98
107
|
href: '/resources/docs/git',
|
|
99
108
|
trackingTarget: 'topnav_resources_docs_git',
|
|
100
109
|
text: 'Git',
|
|
101
|
-
type: 'link'
|
|
110
|
+
type: 'link',
|
|
111
|
+
icon: GitIcon
|
|
102
112
|
}, {
|
|
103
113
|
id: 'php',
|
|
104
114
|
href: '/resources/docs/php',
|
|
105
115
|
trackingTarget: 'topnav_resources_docs_php',
|
|
106
116
|
text: 'PHP',
|
|
107
|
-
type: 'link'
|
|
108
|
-
|
|
109
|
-
id: 'uiux',
|
|
110
|
-
href: '/resources/docs/uiux',
|
|
111
|
-
trackingTarget: 'topnav_resources_docs_uiux',
|
|
112
|
-
text: 'UI/UX',
|
|
113
|
-
type: 'link'
|
|
117
|
+
type: 'link',
|
|
118
|
+
icon: PhpIcon
|
|
114
119
|
}, {
|
|
115
120
|
id: 'markdown',
|
|
116
121
|
href: '/resources/docs/markdown',
|
|
117
122
|
trackingTarget: 'topnav_resources_docs_markdown',
|
|
118
123
|
text: 'Markdown',
|
|
119
|
-
type: 'link'
|
|
120
|
-
|
|
121
|
-
id: 'data-science',
|
|
122
|
-
href: '/resources/docs/data-science',
|
|
123
|
-
trackingTarget: 'topnav_resources_docs_data_science',
|
|
124
|
-
text: 'Data science',
|
|
125
|
-
type: 'link'
|
|
126
|
-
}, {
|
|
127
|
-
id: 'ai',
|
|
128
|
-
href: '/resources/docs/ai',
|
|
129
|
-
trackingTarget: 'topnav_resources_docs_ai',
|
|
130
|
-
text: 'AI',
|
|
131
|
-
type: 'link'
|
|
132
|
-
}, {
|
|
133
|
-
id: 'data-visualization',
|
|
134
|
-
href: '/resources/docs/data-visualization',
|
|
135
|
-
trackingTarget: 'topnav_resources_docs_data_visualization',
|
|
136
|
-
text: 'Data visualization',
|
|
137
|
-
type: 'link'
|
|
124
|
+
type: 'link',
|
|
125
|
+
icon: MarkdownIcon
|
|
138
126
|
}, {
|
|
139
127
|
id: 'typescript',
|
|
140
128
|
href: '/resources/docs/typescript',
|
|
141
129
|
trackingTarget: 'topnav_resources_docs_typescript',
|
|
142
130
|
text: 'TypeScript',
|
|
143
|
-
type: 'link'
|
|
131
|
+
type: 'link',
|
|
132
|
+
icon: TypescriptIcon
|
|
133
|
+
}, {
|
|
134
|
+
id: 'lua',
|
|
135
|
+
href: '/resources/docs/lua',
|
|
136
|
+
trackingTarget: 'topnav_resources_docs_lua',
|
|
137
|
+
text: 'Lua',
|
|
138
|
+
type: 'link',
|
|
139
|
+
icon: GameDevelopmentIcon
|
|
140
|
+
}, {
|
|
141
|
+
id: 'go',
|
|
142
|
+
href: '/resources/docs/go',
|
|
143
|
+
trackingTarget: 'topnav_resources_docs_go',
|
|
144
|
+
text: 'Go',
|
|
145
|
+
type: 'link',
|
|
146
|
+
icon: GoIcon
|
|
144
147
|
}, {
|
|
145
|
-
id: '
|
|
146
|
-
href: '/resources/docs/
|
|
147
|
-
trackingTarget: '
|
|
148
|
-
text: '
|
|
149
|
-
type: 'link'
|
|
148
|
+
id: 'command-line',
|
|
149
|
+
href: '/resources/docs/command-line',
|
|
150
|
+
trackingTarget: 'topnav_resources_docs_command_line',
|
|
151
|
+
text: 'Command line',
|
|
152
|
+
type: 'link',
|
|
153
|
+
icon: TerminalIcon
|
|
154
|
+
}, {
|
|
155
|
+
id: 'powershell',
|
|
156
|
+
href: '/resources/docs/powershell',
|
|
157
|
+
trackingTarget: 'topnav_resources_docs_powershell',
|
|
158
|
+
text: 'Powershell',
|
|
159
|
+
type: 'link',
|
|
160
|
+
icon: ComputerScienceIcon
|
|
161
|
+
}, {
|
|
162
|
+
id: 'swift',
|
|
163
|
+
href: '/resources/docs/swift',
|
|
164
|
+
trackingTarget: 'topnav_resources_docs_swift',
|
|
165
|
+
text: 'Swift',
|
|
166
|
+
type: 'link',
|
|
167
|
+
icon: SwiftIcon
|
|
150
168
|
}];
|
|
151
169
|
export const learningToolsLinks = [{
|
|
152
170
|
linkItem: {
|
|
@@ -157,7 +175,7 @@ export const learningToolsLinks = [{
|
|
|
157
175
|
type: 'link'
|
|
158
176
|
},
|
|
159
177
|
icon: /*#__PURE__*/_jsx(ArticleIcon, {}),
|
|
160
|
-
description:
|
|
178
|
+
description: 'Dive deeper into coding concepts and developer workflows to level up your skills.'
|
|
161
179
|
}, {
|
|
162
180
|
linkItem: {
|
|
163
181
|
id: 'cheatsheets',
|
|
@@ -167,7 +185,7 @@ export const learningToolsLinks = [{
|
|
|
167
185
|
type: 'link'
|
|
168
186
|
},
|
|
169
187
|
icon: /*#__PURE__*/_jsx(NotebookIcon, {}),
|
|
170
|
-
description: 'Quick
|
|
188
|
+
description: 'Quick guides that summarize key concepts across languages, tools, and technologies.'
|
|
171
189
|
}, {
|
|
172
190
|
linkItem: {
|
|
173
191
|
id: 'videos',
|
|
@@ -177,7 +195,7 @@ export const learningToolsLinks = [{
|
|
|
177
195
|
type: 'link'
|
|
178
196
|
},
|
|
179
197
|
icon: /*#__PURE__*/_jsx(VideoPlayerMovieIcon, {}),
|
|
180
|
-
description: '
|
|
198
|
+
description: 'Learn from videos on languages, frameworks, and more—at any skill level.'
|
|
181
199
|
}, {
|
|
182
200
|
linkItem: {
|
|
183
201
|
id: 'projects',
|
|
@@ -187,7 +205,7 @@ export const learningToolsLinks = [{
|
|
|
187
205
|
type: 'link'
|
|
188
206
|
},
|
|
189
207
|
icon: /*#__PURE__*/_jsx(ProjectsIcon, {}),
|
|
190
|
-
description:
|
|
208
|
+
description: 'Apply your skills, connect concepts, and build something of your own.'
|
|
191
209
|
}];
|
|
192
210
|
export const practiceToolsLinks = [{
|
|
193
211
|
linkItem: {
|
|
@@ -197,8 +215,8 @@ export const practiceToolsLinks = [{
|
|
|
197
215
|
text: 'Code Challenges',
|
|
198
216
|
type: 'link'
|
|
199
217
|
},
|
|
200
|
-
icon: /*#__PURE__*/_jsx(
|
|
201
|
-
description:
|
|
218
|
+
icon: /*#__PURE__*/_jsx(ProgrammingBrowserIcon, {}),
|
|
219
|
+
description: 'Sharpen your skills with real interview challenges from top tech companies, with guidance if you get stuck.'
|
|
202
220
|
}, {
|
|
203
221
|
linkItem: {
|
|
204
222
|
id: 'workspaces',
|
|
@@ -207,8 +225,8 @@ export const practiceToolsLinks = [{
|
|
|
207
225
|
text: 'Workspaces',
|
|
208
226
|
type: 'link'
|
|
209
227
|
},
|
|
210
|
-
icon: /*#__PURE__*/_jsx(
|
|
211
|
-
description: '
|
|
228
|
+
icon: /*#__PURE__*/_jsx(LearnIcon, {}),
|
|
229
|
+
description: 'Build and share projects in 13 popular languages, all right in your browser.'
|
|
212
230
|
}, {
|
|
213
231
|
linkItem: {
|
|
214
232
|
id: 'job-readiness',
|
|
@@ -217,8 +235,8 @@ export const practiceToolsLinks = [{
|
|
|
217
235
|
text: 'Job-Readiness Checker',
|
|
218
236
|
type: 'link'
|
|
219
237
|
},
|
|
220
|
-
icon: /*#__PURE__*/_jsx(
|
|
221
|
-
description:
|
|
238
|
+
icon: /*#__PURE__*/_jsx(PeopleIcon, {}),
|
|
239
|
+
description: 'See how your skills match a job posting and get tips on what to improve.'
|
|
222
240
|
}, {
|
|
223
241
|
linkItem: {
|
|
224
242
|
id: 'interview-simulator',
|
|
@@ -227,8 +245,8 @@ export const practiceToolsLinks = [{
|
|
|
227
245
|
text: 'Interview Simulator',
|
|
228
246
|
type: 'link'
|
|
229
247
|
},
|
|
230
|
-
icon: /*#__PURE__*/_jsx(
|
|
231
|
-
description: '
|
|
248
|
+
icon: /*#__PURE__*/_jsx(GaugeDashboardIcon, {}),
|
|
249
|
+
description: 'Practice interviews, get feedback, and build confidence at any stage of your tech career.'
|
|
232
250
|
}];
|
|
233
251
|
export const inspirationLinks = [{
|
|
234
252
|
linkItem: {
|
|
@@ -269,5 +287,5 @@ export const inspirationLinks = [{
|
|
|
269
287
|
type: 'link'
|
|
270
288
|
},
|
|
271
289
|
icon: /*#__PURE__*/_jsx(SearchIcon, {}),
|
|
272
|
-
description: '
|
|
290
|
+
description: 'Master the skills to land a tech job, from resumes and portfolios to interviews and offers.'
|
|
273
291
|
}];
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
2
|
+
import { Anchor, FlexBox, Text } from '@codecademy/gamut';
|
|
3
|
+
import { css, theme } from '@codecademy/gamut-styles';
|
|
4
|
+
import { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';
|
|
5
|
+
import { useAppHeaderDropdownContext } from '../AppHeaderDropdownProvider';
|
|
6
|
+
import { useAppHeaderSectionContext } from '../AppHeaderSection/AppHeaderSectionContext';
|
|
7
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
|
+
const SkillAnchor = /*#__PURE__*/_styled(Anchor, {
|
|
9
|
+
target: "e1t5ouwe0",
|
|
10
|
+
label: "SkillAnchor"
|
|
11
|
+
})(css({
|
|
12
|
+
backgroundColor: theme.colors.background,
|
|
13
|
+
borderColor: theme.colors['border-tertiary'],
|
|
14
|
+
borderRadius: 'lg',
|
|
15
|
+
border: 1,
|
|
16
|
+
'&:hover, &:focus': {
|
|
17
|
+
borderColor: theme.colors.primary,
|
|
18
|
+
background: theme.colors['navy-100']
|
|
19
|
+
},
|
|
20
|
+
'&:active': {
|
|
21
|
+
borderColor: theme.colors.primary,
|
|
22
|
+
background: theme.colors['navy-200']
|
|
23
|
+
}
|
|
24
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2tpbGxUaWxlL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhb0IiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL0FwcEhlYWRlci9BcHBIZWFkZXJFbGVtZW50cy9BcHBIZWFkZXJTa2lsbFRpbGUvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQW5jaG9yLCBGbGV4Qm94LCBUZXh0LCBUZXh0UHJvcHMgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dCc7XG5pbXBvcnQgeyBjc3MsIHRoZW1lIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgdXNlR2xvYmFsSGVhZGVySXRlbUNsaWNrIH0gZnJvbSAnLi4vLi4vLi4vR2xvYmFsSGVhZGVyL2NvbnRleHQnO1xuaW1wb3J0IHsgQXBwSGVhZGVyTGlua0l0ZW0gfSBmcm9tICcuLi8uLi9zaGFyZWQnO1xuaW1wb3J0IHsgdXNlQXBwSGVhZGVyRHJvcGRvd25Db250ZXh0IH0gZnJvbSAnLi4vQXBwSGVhZGVyRHJvcGRvd25Qcm92aWRlcic7XG5pbXBvcnQgeyB1c2VBcHBIZWFkZXJTZWN0aW9uQ29udGV4dCB9IGZyb20gJy4uL0FwcEhlYWRlclNlY3Rpb24vQXBwSGVhZGVyU2VjdGlvbkNvbnRleHQnO1xuXG5pbnRlcmZhY2UgU2tpbGxUaWxlUHJvcHMge1xuICBpdGVtOiBBcHBIZWFkZXJMaW5rSXRlbTtcbn1cblxuY29uc3QgU2tpbGxBbmNob3IgPSBzdHlsZWQoQW5jaG9yKShcbiAgY3NzKHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kLFxuICAgIGJvcmRlckNvbG9yOiB0aGVtZS5jb2xvcnNbJ2JvcmRlci10ZXJ0aWFyeSddIGFzIFRleHRQcm9wc1snY29sb3InXSxcbiAgICBib3JkZXJSYWRpdXM6ICdsZycsXG4gICAgYm9yZGVyOiAxLFxuICAgICcmOmhvdmVyLCAmOmZvY3VzJzoge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLmNvbG9ycy5wcmltYXJ5IGFzIFRleHRQcm9wc1snY29sb3InXSxcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLmNvbG9yc1snbmF2eS0xMDAnXSxcbiAgICB9LFxuICAgICcmOmFjdGl2ZSc6IHtcbiAgICAgIGJvcmRlckNvbG9yOiB0aGVtZS5jb2xvcnMucHJpbWFyeSBhcyBUZXh0UHJvcHNbJ2NvbG9yJ10sXG4gICAgICBiYWNrZ3JvdW5kOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgfSxcbiAgfSlcbik7XG5cbmV4cG9ydCBjb25zdCBTa2lsbFRpbGU6IFJlYWN0LkZDPFNraWxsVGlsZVByb3BzPiA9ICh7IGl0ZW0gfSkgPT4ge1xuICBjb25zdCB7IGhyZWYsIHRleHQsIGljb246IEljb24gfSA9IGl0ZW07XG4gIGNvbnN0IHsgZ2xvYmFsSGVhZGVySXRlbUNsaWNrIH0gPSB1c2VHbG9iYWxIZWFkZXJJdGVtQ2xpY2soKTtcbiAgY29uc3QgeyBoYW5kbGVDbG9zZSB9ID0gdXNlQXBwSGVhZGVyRHJvcGRvd25Db250ZXh0KCk7XG4gIGNvbnN0IHsgdGFiSW5kZXggfSA9IHVzZUFwcEhlYWRlclNlY3Rpb25Db250ZXh0KCk7XG5cbiAgcmV0dXJuIChcbiAgICA8U2tpbGxBbmNob3JcbiAgICAgIGhyZWY9e2hyZWZ9XG4gICAgICBvbkNsaWNrPXsoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTEFuY2hvckVsZW1lbnQsIE1vdXNlRXZlbnQ+KSA9PiB7XG4gICAgICAgIGdsb2JhbEhlYWRlckl0ZW1DbGljayhldmVudCwgaXRlbSk7XG4gICAgICAgIGhhbmRsZUNsb3NlKCk7XG4gICAgICB9fVxuICAgICAgdmFyaWFudD1cImludGVyZmFjZVwiXG4gICAgICB3aWR0aD1cIjEwMCVcIlxuICAgICAgdGFiSW5kZXg9e3RhYkluZGV4fVxuICAgID5cbiAgICAgIDxGbGV4Qm94IHB5PXs4fSBweD17MTZ9IGhlaWdodD17NDh9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge0ljb24gJiYgPEljb24gc2l6ZT17MjR9IC8+fVxuICAgICAgICA8VGV4dCB2YXJpYW50PVwicC1iYXNlXCIgcGw9ezE2fT5cbiAgICAgICAgICB7dGV4dH1cbiAgICAgICAgPC9UZXh0PlxuICAgICAgPC9GbGV4Qm94PlxuICAgIDwvU2tpbGxBbmNob3I+XG4gICk7XG59O1xuIl19 */");
|
|
25
|
+
export const SkillTile = ({
|
|
26
|
+
item
|
|
27
|
+
}) => {
|
|
28
|
+
const {
|
|
29
|
+
href,
|
|
30
|
+
text,
|
|
31
|
+
icon: Icon
|
|
32
|
+
} = item;
|
|
33
|
+
const {
|
|
34
|
+
globalHeaderItemClick
|
|
35
|
+
} = useGlobalHeaderItemClick();
|
|
36
|
+
const {
|
|
37
|
+
handleClose
|
|
38
|
+
} = useAppHeaderDropdownContext();
|
|
39
|
+
const {
|
|
40
|
+
tabIndex
|
|
41
|
+
} = useAppHeaderSectionContext();
|
|
42
|
+
return /*#__PURE__*/_jsx(SkillAnchor, {
|
|
43
|
+
href: href,
|
|
44
|
+
onClick: event => {
|
|
45
|
+
globalHeaderItemClick(event, item);
|
|
46
|
+
handleClose();
|
|
47
|
+
},
|
|
48
|
+
variant: "interface",
|
|
49
|
+
width: "100%",
|
|
50
|
+
tabIndex: tabIndex,
|
|
51
|
+
children: /*#__PURE__*/_jsxs(FlexBox, {
|
|
52
|
+
py: 8,
|
|
53
|
+
px: 16,
|
|
54
|
+
height: 48,
|
|
55
|
+
alignItems: "center",
|
|
56
|
+
children: [Icon && /*#__PURE__*/_jsx(Icon, {
|
|
57
|
+
size: 24
|
|
58
|
+
}), /*#__PURE__*/_jsx(Text, {
|
|
59
|
+
variant: "p-base",
|
|
60
|
+
pl: 16,
|
|
61
|
+
children: text
|
|
62
|
+
})]
|
|
63
|
+
})
|
|
64
|
+
});
|
|
65
|
+
};
|
|
@@ -2,15 +2,11 @@ import { PlansByType } from '../config';
|
|
|
2
2
|
import { Product, ProductDetails, User } from '../types';
|
|
3
3
|
import { AllCurrency } from './types';
|
|
4
4
|
export declare const smSize = 728;
|
|
5
|
-
export declare const PricingCard: ({ product, productDetails, currency, plansByType, isUserInIndia, user,
|
|
5
|
+
export declare const PricingCard: ({ product, productDetails, currency, plansByType, isUserInIndia, user, }: {
|
|
6
6
|
product: Product;
|
|
7
7
|
productDetails: ProductDetails;
|
|
8
8
|
currency: AllCurrency;
|
|
9
9
|
plansByType: PlansByType;
|
|
10
10
|
isUserInIndia: boolean;
|
|
11
11
|
user: User;
|
|
12
|
-
trackBusinessClick?: ({ target, context, }: {
|
|
13
|
-
target: string;
|
|
14
|
-
context: string;
|
|
15
|
-
}) => void;
|
|
16
12
|
}) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -19,17 +19,17 @@ const StyledCard = /*#__PURE__*/_styled(Card, {
|
|
|
19
19
|
padding: 0,
|
|
20
20
|
width: '100%',
|
|
21
21
|
flexDirection: 'column'
|
|
22
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZW1CIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYWRnZSwgQm94LCBDYXJkLCBGbGV4Qm94LCBUZXh0IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQnO1xuaW1wb3J0IHsgQ2hlY2tlckRlbnNlIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtcGF0dGVybnMnO1xuaW1wb3J0IHsgY3NzLCBweFJlbSwgdGhlbWUsIHZhcmlhbnQgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5pbXBvcnQgeyBDb25kaXRpb25hbENvbG9yTW9kZSB9IGZyb20gJy4uL0NvbmRpdGlvbmFsQ29sb3JNb2RlJztcbmltcG9ydCB7IGdldFByb2R1Y3REZXNjcmlwdGlvbiwgUGxhbnNCeVR5cGUgfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvZHVjdENUQSB9IGZyb20gJy4uL1Byb2R1Y3RDVEEnO1xuaW1wb3J0IHsgUHJvZHVjdCwgUHJvZHVjdERldGFpbHMsIFVzZXIgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBQcmljaW5nQW1vdW50IH0gZnJvbSAnLi9QcmljaW5nQW1vdW50JztcbmltcG9ydCB7IFJlY29tbWVuZGVkQmFkZ2UgfSBmcm9tICcuL1JlY29tbWVuZGVkQmFkZ2UnO1xuaW1wb3J0IHsgQWxsQ3VycmVuY3kgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IHNtU2l6ZSA9IDcyODtcblxuY29uc3QgU3R5bGVkQ2FyZCA9IHN0eWxlZChDYXJkKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6IDEsXG4gICAgYm9yZGVyV2lkdGg6IDAsXG4gICAgcGFkZGluZzogMCxcbiAgICB3aWR0aDogJzEwMCUnLFxuICAgIGZsZXhEaXJlY3Rpb246ICdjb2x1bW4nLFxuICB9KVxuKTtcblxuY29uc3QgRGl2aWRlciA9IHN0eWxlZChDaGVja2VyRGVuc2UpKFxuICBjc3Moe1xuICAgIGhlaWdodDogJzAuMXJlbScsXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZExpc3RSb3dQcm9wcyA9IHtcbiAgc2hvd1JlY29tbWVuZGVkQmFkZ2U6IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRMaXN0Um93ID0gc3R5bGVkKCdsaScpPFN0eWxlZExpc3RSb3dQcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6ICR7cHhSZW0oc21TaXplKX07XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgJHt0aGVtZS5icmVha3BvaW50cy5sZ30ge1xuICAgIG1pbi13aWR0aDogMzZyZW07XG4gIH1cbmA7XG5cbmNvbnN0IGNhcmRIZWFkZXJWYXJpYW50cyA9IHZhcmlhbnQoe1xuICBiYXNlOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAndHJhbnNwYXJlbnQnLFxuICB9LFxuICB2YXJpYW50czoge1xuICAgIFtQcm9kdWN0LkJhc2ljXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LkVudGVycHJpc2VdOiB7XG4gICAgICBib3JkZXJCb3R0b21XaWR0aDogMSxcbiAgICAgIGJvcmRlckJvdHRvbVN0eWxlOiAnc29saWQnLFxuICAgICAgYm9yZGVyQm90dG9tQ29sb3I6IHRoZW1lLmNvbG9yc1snbmF2eS0yMDAnXSxcbiAgICAgIGNvbG9yOiAnbmF2eS01MDAnLFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuU2lsdmVyXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMucGFsZVllbGxvdyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LkdvbGRdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy55ZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Qcm9dOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy55ZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5UZWFtc106IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLmJhY2tncm91bmQsXG4gICAgfSxcbiAgfSxcbn0pO1xuXG5jb25zdCBDYXJkSGVhZGVyID0gc3R5bGVkKEZsZXhCb3gpKGNhcmRIZWFkZXJWYXJpYW50cyk7XG5cbmNvbnN0IGdldEJhZGdlVGV4dCA9IChwcm9kdWN0OiBQcm9kdWN0KTogc3RyaW5nIHwgbnVsbCA9PiB7XG4gIHN3aXRjaCAocHJvZHVjdCkge1xuICAgIGNhc2UgUHJvZHVjdC5Hb2xkOlxuICAgICAgcmV0dXJuICdBZHZhbmNlIHlvdXIgY2FyZWVyJztcbiAgICBjYXNlIFByb2R1Y3QuU2lsdmVyOlxuICAgIGNhc2UgUHJvZHVjdC5Qcm86XG4gICAgICByZXR1cm4gJ0xlYXJuIGEgc2tpbGwnO1xuICAgIGNhc2UgUHJvZHVjdC5UZWFtczpcbiAgICAgIHJldHVybiAnUmVjb21tZW5kZWQgZm9yIDIrJztcbiAgICBjYXNlIFByb2R1Y3QuRW50ZXJwcmlzZTpcbiAgICAgIHJldHVybiAnUmVjb21tZW5kZWQgZm9yIDI1Kyc7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBudWxsO1xuICB9XG59O1xuXG5jb25zdCByZW5kZXJQcm9kdWN0RGVzY3JpcHRpb24gPSAocHJvZHVjdDogUHJvZHVjdCkgPT4ge1xuICBjb25zdCBwcm9kdWN0RmVhdHVyZXMgPSAoXG4gICAgPFRleHQgbWF4V2lkdGg9e3sgbWQ6ICcyMzVweCcgfX0gdGV4dEFsaWduPVwiY2VudGVyXCI+XG4gICAgICB7Z2V0UHJvZHVjdERlc2NyaXB0aW9uKHByb2R1Y3QpfVxuICAgIDwvVGV4dD5cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxGbGV4Qm94IG10PXs4fSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgZmxleERpcmVjdGlvbj1cImNvbHVtblwiPlxuICAgICAge3Byb2R1Y3RGZWF0dXJlc31cbiAgICA8L0ZsZXhCb3g+
|
|
22
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AAemB","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */");
|
|
23
23
|
const Divider = /*#__PURE__*/_styled(CheckerDense, {
|
|
24
24
|
target: "e3n4z5j2",
|
|
25
25
|
label: "Divider"
|
|
26
26
|
})(css({
|
|
27
27
|
height: '0.1rem'
|
|
28
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJnQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUHJpY2luZ1NlY3Rpb24vUHJpY2luZ0NhcmQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IENoZWNrZXJEZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IGNzcywgcHhSZW0sIHRoZW1lLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQ29uZGl0aW9uYWxDb2xvck1vZGUgfSBmcm9tICcuLi9Db25kaXRpb25hbENvbG9yTW9kZSc7XG5pbXBvcnQgeyBnZXRQcm9kdWN0RGVzY3JpcHRpb24sIFBsYW5zQnlUeXBlIH0gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7IFByb2R1Y3RDVEEgfSBmcm9tICcuLi9Qcm9kdWN0Q1RBJztcbmltcG9ydCB7IFByb2R1Y3QsIFByb2R1Y3REZXRhaWxzLCBVc2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgUHJpY2luZ0Ftb3VudCB9IGZyb20gJy4vUHJpY2luZ0Ftb3VudCc7XG5pbXBvcnQgeyBSZWNvbW1lbmRlZEJhZGdlIH0gZnJvbSAnLi9SZWNvbW1lbmRlZEJhZGdlJztcbmltcG9ydCB7IEFsbEN1cnJlbmN5IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBzbVNpemUgPSA3Mjg7XG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQoQ2FyZCkoXG4gIGNzcyh7XG4gICAgaGVpZ2h0OiAxLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6ICcxMDAlJyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgfSlcbik7XG5cbmNvbnN0IERpdmlkZXIgPSBzdHlsZWQoQ2hlY2tlckRlbnNlKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6ICcwLjFyZW0nLFxuICB9KVxuKTtcblxudHlwZSBTdHlsZWRMaXN0Um93UHJvcHMgPSB7XG4gIHNob3dSZWNvbW1lbmRlZEJhZGdlOiBib29sZWFuO1xufTtcblxuY29uc3QgU3R5bGVkTGlzdFJvdyA9IHN0eWxlZCgnbGknKTxTdHlsZWRMaXN0Um93UHJvcHM+YFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiAke3B4UmVtKHNtU2l6ZSl9O1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7dGhlbWUuYnJlYWtwb2ludHMubGd9IHtcbiAgICBtaW4td2lkdGg6IDM2cmVtO1xuICB9XG5gO1xuXG5jb25zdCBjYXJkSGVhZGVyVmFyaWFudHMgPSB2YXJpYW50KHtcbiAgYmFzZToge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgfSxcbiAgdmFyaWFudHM6IHtcbiAgICBbUHJvZHVjdC5CYXNpY106IHtcbiAgICAgIGJvcmRlckJvdHRvbVdpZHRoOiAxLFxuICAgICAgYm9yZGVyQm90dG9tU3R5bGU6ICdzb2xpZCcsXG4gICAgICBib3JkZXJCb3R0b21Db2xvcjogdGhlbWUuY29sb3JzWyduYXZ5LTIwMCddLFxuICAgICAgY29sb3I6ICduYXZ5LTUwMCcsXG4gICAgfSxcbiAgICBbUHJvZHVjdC5FbnRlcnByaXNlXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LlNpbHZlcl06IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLnBhbGVZZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Hb2xkXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuUHJvXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuVGVhbXNdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kLFxuICAgIH0sXG4gIH0sXG59KTtcblxuY29uc3QgQ2FyZEhlYWRlciA9IHN0eWxlZChGbGV4Qm94KShjYXJkSGVhZGVyVmFyaWFudHMpO1xuXG5jb25zdCBnZXRCYWRnZVRleHQgPSAocHJvZHVjdDogUHJvZHVjdCk6IHN0cmluZyB8IG51bGwgPT4ge1xuICBzd2l0Y2ggKHByb2R1Y3QpIHtcbiAgICBjYXNlIFByb2R1Y3QuR29sZDpcbiAgICAgIHJldHVybiAnQWR2YW5jZSB5b3VyIGNhcmVlcic7XG4gICAgY2FzZSBQcm9kdWN0LlNpbHZlcjpcbiAgICBjYXNlIFByb2R1Y3QuUHJvOlxuICAgICAgcmV0dXJuICdMZWFybiBhIHNraWxsJztcbiAgICBjYXNlIFByb2R1Y3QuVGVhbXM6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyKyc7XG4gICAgY2FzZSBQcm9kdWN0LkVudGVycHJpc2U6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyNSsnO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gbnVsbDtcbiAgfVxufTtcblxuY29uc3QgcmVuZGVyUHJvZHVjdERlc2NyaXB0aW9uID0gKHByb2R1Y3Q6IFByb2R1Y3QpID0+IHtcbiAgY29uc3QgcHJvZHVjdEZlYXR1cmVzID0gKFxuICAgIDxUZXh0IG1heFdpZHRoPXt7IG1kOiAnMjM1cHgnIH19IHRleHRBbGlnbj1cImNlbnRlclwiPlxuICAgICAge2dldFByb2R1Y3REZXNjcmlwdGlvbihwcm9kdWN0KX1cbiAgICA8L1RleHQ+
|
|
28
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AAyBgB","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */");
|
|
29
29
|
const StyledListRow = /*#__PURE__*/_styled('li', {
|
|
30
30
|
target: "e3n4z5j1",
|
|
31
31
|
label: "StyledListRow"
|
|
32
|
-
})("width:100%;max-width:", pxRem(smSize), ";height:100%;display:grid;", theme.breakpoints.lg, "{min-width:36rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUNzRCIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUHJpY2luZ1NlY3Rpb24vUHJpY2luZ0NhcmQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IENoZWNrZXJEZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IGNzcywgcHhSZW0sIHRoZW1lLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQ29uZGl0aW9uYWxDb2xvck1vZGUgfSBmcm9tICcuLi9Db25kaXRpb25hbENvbG9yTW9kZSc7XG5pbXBvcnQgeyBnZXRQcm9kdWN0RGVzY3JpcHRpb24sIFBsYW5zQnlUeXBlIH0gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7IFByb2R1Y3RDVEEgfSBmcm9tICcuLi9Qcm9kdWN0Q1RBJztcbmltcG9ydCB7IFByb2R1Y3QsIFByb2R1Y3REZXRhaWxzLCBVc2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgUHJpY2luZ0Ftb3VudCB9IGZyb20gJy4vUHJpY2luZ0Ftb3VudCc7XG5pbXBvcnQgeyBSZWNvbW1lbmRlZEJhZGdlIH0gZnJvbSAnLi9SZWNvbW1lbmRlZEJhZGdlJztcbmltcG9ydCB7IEFsbEN1cnJlbmN5IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBzbVNpemUgPSA3Mjg7XG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQoQ2FyZCkoXG4gIGNzcyh7XG4gICAgaGVpZ2h0OiAxLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6ICcxMDAlJyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgfSlcbik7XG5cbmNvbnN0IERpdmlkZXIgPSBzdHlsZWQoQ2hlY2tlckRlbnNlKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6ICcwLjFyZW0nLFxuICB9KVxuKTtcblxudHlwZSBTdHlsZWRMaXN0Um93UHJvcHMgPSB7XG4gIHNob3dSZWNvbW1lbmRlZEJhZGdlOiBib29sZWFuO1xufTtcblxuY29uc3QgU3R5bGVkTGlzdFJvdyA9IHN0eWxlZCgnbGknKTxTdHlsZWRMaXN0Um93UHJvcHM+YFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiAke3B4UmVtKHNtU2l6ZSl9O1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7dGhlbWUuYnJlYWtwb2ludHMubGd9IHtcbiAgICBtaW4td2lkdGg6IDM2cmVtO1xuICB9XG5gO1xuXG5jb25zdCBjYXJkSGVhZGVyVmFyaWFudHMgPSB2YXJpYW50KHtcbiAgYmFzZToge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgfSxcbiAgdmFyaWFudHM6IHtcbiAgICBbUHJvZHVjdC5CYXNpY106IHtcbiAgICAgIGJvcmRlckJvdHRvbVdpZHRoOiAxLFxuICAgICAgYm9yZGVyQm90dG9tU3R5bGU6ICdzb2xpZCcsXG4gICAgICBib3JkZXJCb3R0b21Db2xvcjogdGhlbWUuY29sb3JzWyduYXZ5LTIwMCddLFxuICAgICAgY29sb3I6ICduYXZ5LTUwMCcsXG4gICAgfSxcbiAgICBbUHJvZHVjdC5FbnRlcnByaXNlXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LlNpbHZlcl06IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLnBhbGVZZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Hb2xkXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuUHJvXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuVGVhbXNdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kLFxuICAgIH0sXG4gIH0sXG59KTtcblxuY29uc3QgQ2FyZEhlYWRlciA9IHN0eWxlZChGbGV4Qm94KShjYXJkSGVhZGVyVmFyaWFudHMpO1xuXG5jb25zdCBnZXRCYWRnZVRleHQgPSAocHJvZHVjdDogUHJvZHVjdCk6IHN0cmluZyB8IG51bGwgPT4ge1xuICBzd2l0Y2ggKHByb2R1Y3QpIHtcbiAgICBjYXNlIFByb2R1Y3QuR29sZDpcbiAgICAgIHJldHVybiAnQWR2YW5jZSB5b3VyIGNhcmVlcic7XG4gICAgY2FzZSBQcm9kdWN0LlNpbHZlcjpcbiAgICBjYXNlIFByb2R1Y3QuUHJvOlxuICAgICAgcmV0dXJuICdMZWFybiBhIHNraWxsJztcbiAgICBjYXNlIFByb2R1Y3QuVGVhbXM6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyKyc7XG4gICAgY2FzZSBQcm9kdWN0LkVudGVycHJpc2U6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyNSsnO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gbnVsbDtcbiAgfVxufTtcblxuY29uc3QgcmVuZGVyUHJvZHVjdERlc2NyaXB0aW9uID0gKHByb2R1Y3Q6IFByb2R1Y3QpID0+IHtcbiAgY29uc3QgcHJvZHVjdEZlYXR1cmVzID0gKFxuICAgIDxUZXh0IG1heFdpZHRoPXt7IG1kOiAnMjM1cHgnIH19IHRleHRBbGlnbj1cImNlbnRlclwiPlxuICAgICAge2dldFByb2R1Y3REZXNjcmlwdGlvbihwcm9kdWN0KX1cbiAgICA8L1RleHQ+
|
|
32
|
+
})("width:100%;max-width:", pxRem(smSize), ";height:100%;display:grid;", theme.breakpoints.lg, "{min-width:36rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AAmCsD","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */"));
|
|
33
33
|
const cardHeaderVariants = variant({
|
|
34
34
|
base: {
|
|
35
35
|
backgroundColor: 'transparent'
|
|
@@ -64,7 +64,7 @@ const cardHeaderVariants = variant({
|
|
|
64
64
|
const CardHeader = /*#__PURE__*/_styled(FlexBox, {
|
|
65
65
|
target: "e3n4z5j0",
|
|
66
66
|
label: "CardHeader"
|
|
67
|
-
})(cardHeaderVariants, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkVtQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUHJpY2luZ1NlY3Rpb24vUHJpY2luZ0NhcmQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IENoZWNrZXJEZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IGNzcywgcHhSZW0sIHRoZW1lLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQ29uZGl0aW9uYWxDb2xvck1vZGUgfSBmcm9tICcuLi9Db25kaXRpb25hbENvbG9yTW9kZSc7XG5pbXBvcnQgeyBnZXRQcm9kdWN0RGVzY3JpcHRpb24sIFBsYW5zQnlUeXBlIH0gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7IFByb2R1Y3RDVEEgfSBmcm9tICcuLi9Qcm9kdWN0Q1RBJztcbmltcG9ydCB7IFByb2R1Y3QsIFByb2R1Y3REZXRhaWxzLCBVc2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgUHJpY2luZ0Ftb3VudCB9IGZyb20gJy4vUHJpY2luZ0Ftb3VudCc7XG5pbXBvcnQgeyBSZWNvbW1lbmRlZEJhZGdlIH0gZnJvbSAnLi9SZWNvbW1lbmRlZEJhZGdlJztcbmltcG9ydCB7IEFsbEN1cnJlbmN5IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBzbVNpemUgPSA3Mjg7XG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQoQ2FyZCkoXG4gIGNzcyh7XG4gICAgaGVpZ2h0OiAxLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6ICcxMDAlJyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgfSlcbik7XG5cbmNvbnN0IERpdmlkZXIgPSBzdHlsZWQoQ2hlY2tlckRlbnNlKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6ICcwLjFyZW0nLFxuICB9KVxuKTtcblxudHlwZSBTdHlsZWRMaXN0Um93UHJvcHMgPSB7XG4gIHNob3dSZWNvbW1lbmRlZEJhZGdlOiBib29sZWFuO1xufTtcblxuY29uc3QgU3R5bGVkTGlzdFJvdyA9IHN0eWxlZCgnbGknKTxTdHlsZWRMaXN0Um93UHJvcHM+YFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiAke3B4UmVtKHNtU2l6ZSl9O1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7dGhlbWUuYnJlYWtwb2ludHMubGd9IHtcbiAgICBtaW4td2lkdGg6IDM2cmVtO1xuICB9XG5gO1xuXG5jb25zdCBjYXJkSGVhZGVyVmFyaWFudHMgPSB2YXJpYW50KHtcbiAgYmFzZToge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgfSxcbiAgdmFyaWFudHM6IHtcbiAgICBbUHJvZHVjdC5CYXNpY106IHtcbiAgICAgIGJvcmRlckJvdHRvbVdpZHRoOiAxLFxuICAgICAgYm9yZGVyQm90dG9tU3R5bGU6ICdzb2xpZCcsXG4gICAgICBib3JkZXJCb3R0b21Db2xvcjogdGhlbWUuY29sb3JzWyduYXZ5LTIwMCddLFxuICAgICAgY29sb3I6ICduYXZ5LTUwMCcsXG4gICAgfSxcbiAgICBbUHJvZHVjdC5FbnRlcnByaXNlXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LlNpbHZlcl06IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLnBhbGVZZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Hb2xkXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuUHJvXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuVGVhbXNdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kLFxuICAgIH0sXG4gIH0sXG59KTtcblxuY29uc3QgQ2FyZEhlYWRlciA9IHN0eWxlZChGbGV4Qm94KShjYXJkSGVhZGVyVmFyaWFudHMpO1xuXG5jb25zdCBnZXRCYWRnZVRleHQgPSAocHJvZHVjdDogUHJvZHVjdCk6IHN0cmluZyB8IG51bGwgPT4ge1xuICBzd2l0Y2ggKHByb2R1Y3QpIHtcbiAgICBjYXNlIFByb2R1Y3QuR29sZDpcbiAgICAgIHJldHVybiAnQWR2YW5jZSB5b3VyIGNhcmVlcic7XG4gICAgY2FzZSBQcm9kdWN0LlNpbHZlcjpcbiAgICBjYXNlIFByb2R1Y3QuUHJvOlxuICAgICAgcmV0dXJuICdMZWFybiBhIHNraWxsJztcbiAgICBjYXNlIFByb2R1Y3QuVGVhbXM6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyKyc7XG4gICAgY2FzZSBQcm9kdWN0LkVudGVycHJpc2U6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyNSsnO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gbnVsbDtcbiAgfVxufTtcblxuY29uc3QgcmVuZGVyUHJvZHVjdERlc2NyaXB0aW9uID0gKHByb2R1Y3Q6IFByb2R1Y3QpID0+IHtcbiAgY29uc3QgcHJvZHVjdEZlYXR1cmVzID0gKFxuICAgIDxUZXh0IG1heFdpZHRoPXt7IG1kOiAnMjM1cHgnIH19IHRleHRBbGlnbj1cImNlbnRlclwiPlxuICAgICAge2dldFByb2R1Y3REZXNjcmlwdGlvbihwcm9kdWN0KX1cbiAgICA8L1RleHQ+
|
|
67
|
+
})(cardHeaderVariants, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AA6EmB","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */");
|
|
68
68
|
const getBadgeText = product => {
|
|
69
69
|
switch (product) {
|
|
70
70
|
case Product.Gold:
|
|
@@ -101,8 +101,7 @@ export const PricingCard = ({
|
|
|
101
101
|
currency,
|
|
102
102
|
plansByType,
|
|
103
103
|
isUserInIndia,
|
|
104
|
-
user
|
|
105
|
-
trackBusinessClick
|
|
104
|
+
user
|
|
106
105
|
}) => {
|
|
107
106
|
const isGoldProduct = product === Product.Gold;
|
|
108
107
|
const isTeamsProduct = product === Product.Teams;
|
|
@@ -193,8 +192,7 @@ export const PricingCard = ({
|
|
|
193
192
|
children: /*#__PURE__*/_jsx(ProductCTA, {
|
|
194
193
|
user: user,
|
|
195
194
|
productDetails: productDetails,
|
|
196
|
-
product: product
|
|
197
|
-
trackBusinessClick: trackBusinessClick
|
|
195
|
+
product: product
|
|
198
196
|
})
|
|
199
197
|
})]
|
|
200
198
|
})
|
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
import { Product, ProductDetails, User } from './types';
|
|
2
2
|
export declare const getCTATitle: (product: Product, isTrialPlan: boolean, isPlusUser?: boolean) => "" | "Request a demo" | "Try Teams for free" | "Purchase now" | "Sign up" | "Try Pro for free" | "Upgrade to Pro" | "Upgrade now" | "Try Plus for free" | "Your current plan";
|
|
3
|
-
export declare const ProductCTA: ({ product, productDetails, user, simple,
|
|
3
|
+
export declare const ProductCTA: ({ product, productDetails, user, simple, }: {
|
|
4
4
|
product: Product;
|
|
5
5
|
productDetails: ProductDetails;
|
|
6
6
|
user: User;
|
|
7
7
|
simple?: boolean;
|
|
8
|
-
trackBusinessClick?: ({ target, context, }: {
|
|
9
|
-
target: string;
|
|
10
|
-
context: string;
|
|
11
|
-
}) => void;
|
|
12
8
|
}) => import("react/jsx-runtime").JSX.Element | null;
|
|
@@ -57,13 +57,11 @@ export const ProductCTA = ({
|
|
|
57
57
|
product,
|
|
58
58
|
productDetails,
|
|
59
59
|
user,
|
|
60
|
-
simple
|
|
61
|
-
trackBusinessClick
|
|
60
|
+
simple
|
|
62
61
|
}) => {
|
|
63
62
|
const userHasBasic = !user.anonymous && (!user.proSilver || !user.proGold);
|
|
64
63
|
const userHasSilver = user.proSilver;
|
|
65
64
|
const isTeams = product === Product.Teams;
|
|
66
|
-
const isEnterprise = product === Product.Enterprise;
|
|
67
65
|
const shouldHideCTA = () => {
|
|
68
66
|
if (isTeams) return false;
|
|
69
67
|
if ((userHasBasic || userHasSilver) && product === Product.Basic) {
|
|
@@ -90,22 +88,6 @@ export const ProductCTA = ({
|
|
|
90
88
|
product,
|
|
91
89
|
userHasSilver
|
|
92
90
|
}),
|
|
93
|
-
onClick: () => {
|
|
94
|
-
if (trackBusinessClick) {
|
|
95
|
-
if (isTeams) {
|
|
96
|
-
trackBusinessClick({
|
|
97
|
-
target: 'business_trial',
|
|
98
|
-
context: 'top_card'
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
if (isEnterprise) {
|
|
102
|
-
trackBusinessClick({
|
|
103
|
-
target: 'business_enterprise',
|
|
104
|
-
context: 'top_card'
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
},
|
|
109
91
|
children: /*#__PURE__*/_jsx(Text, {
|
|
110
92
|
as: "span",
|
|
111
93
|
children: getCTATitle(product, !!productDetails?.isTrialPlan, userHasSilver)
|
|
@@ -119,14 +101,6 @@ export const ProductCTA = ({
|
|
|
119
101
|
mt: 8,
|
|
120
102
|
children: /*#__PURE__*/_jsx(StrokeButton, {
|
|
121
103
|
href: "/business/checkout?plan_type=directpurchase",
|
|
122
|
-
onClick: () => {
|
|
123
|
-
if (trackBusinessClick) {
|
|
124
|
-
trackBusinessClick({
|
|
125
|
-
target: 'business_purchase',
|
|
126
|
-
context: 'top_card'
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
},
|
|
130
104
|
children: "Purchase now"
|
|
131
105
|
})
|
|
132
106
|
})]
|
|
@@ -6,10 +6,6 @@ interface ProductsProps {
|
|
|
6
6
|
user: User;
|
|
7
7
|
isUserInIndia: boolean;
|
|
8
8
|
currency: AllCurrency;
|
|
9
|
-
trackBusinessClick: ({ target, context, }: {
|
|
10
|
-
target: string;
|
|
11
|
-
context: string;
|
|
12
|
-
}) => void;
|
|
13
9
|
}
|
|
14
10
|
export declare const Products: React.FC<ProductsProps>;
|
|
15
11
|
export {};
|
|
@@ -7,8 +7,7 @@ export const Products = ({
|
|
|
7
7
|
plansByType,
|
|
8
8
|
user,
|
|
9
9
|
isUserInIndia,
|
|
10
|
-
currency
|
|
11
|
-
trackBusinessClick
|
|
10
|
+
currency
|
|
12
11
|
}) => {
|
|
13
12
|
const productsLength = Object.keys(plansByType).length;
|
|
14
13
|
const renderCard = product => {
|
|
@@ -47,8 +46,7 @@ export const Products = ({
|
|
|
47
46
|
plansByType: plansByType,
|
|
48
47
|
isUserInIndia: isUserInIndia,
|
|
49
48
|
currency: currency,
|
|
50
|
-
user: user
|
|
51
|
-
trackBusinessClick: trackBusinessClick
|
|
49
|
+
user: user
|
|
52
50
|
}, product);
|
|
53
51
|
case Product.Enterprise:
|
|
54
52
|
return /*#__PURE__*/_jsx(PricingCard, {
|
|
@@ -57,8 +55,7 @@ export const Products = ({
|
|
|
57
55
|
plansByType: plansByType,
|
|
58
56
|
isUserInIndia: isUserInIndia,
|
|
59
57
|
currency: currency,
|
|
60
|
-
user: user
|
|
61
|
-
trackBusinessClick: trackBusinessClick
|
|
58
|
+
user: user
|
|
62
59
|
}, product);
|
|
63
60
|
default:
|
|
64
61
|
return null;
|
|
@@ -7,10 +7,6 @@ type PricingSectionProps = Omit<Partial<React.ComponentProps<typeof Background>>
|
|
|
7
7
|
user: User;
|
|
8
8
|
isUserInIndia: boolean;
|
|
9
9
|
currency: AllCurrency;
|
|
10
|
-
trackBusinessClick: ({ target, context, }: {
|
|
11
|
-
target: string;
|
|
12
|
-
context: string;
|
|
13
|
-
}) => void;
|
|
14
10
|
};
|
|
15
11
|
export declare const PricingSection: React.FC<PricingSectionProps>;
|
|
16
12
|
export {};
|
|
@@ -8,8 +8,7 @@ export const PricingSection = ({
|
|
|
8
8
|
title,
|
|
9
9
|
user,
|
|
10
10
|
isUserInIndia,
|
|
11
|
-
currency
|
|
12
|
-
trackBusinessClick
|
|
11
|
+
currency
|
|
13
12
|
}) => {
|
|
14
13
|
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
15
14
|
children: [/*#__PURE__*/_jsx(Text, {
|
|
@@ -32,8 +31,7 @@ export const PricingSection = ({
|
|
|
32
31
|
plansByType: groupPlansByType(products),
|
|
33
32
|
user: user,
|
|
34
33
|
isUserInIndia: isUserInIndia,
|
|
35
|
-
currency: currency
|
|
36
|
-
trackBusinessClick: trackBusinessClick
|
|
34
|
+
currency: currency
|
|
37
35
|
})
|
|
38
36
|
})]
|
|
39
37
|
})]
|
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.9.0
|
|
4
|
+
"version": "3.9.0",
|
|
5
5
|
"author": "Codecademy Engineering <dev@codecademy.com>",
|
|
6
6
|
"dependencies": {
|
|
7
7
|
"@emotion/is-prop-valid": "^1.2.1",
|