@codecademy/brand 3.7.0 → 3.8.0-alpha.923923e1fa.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,5 +5,6 @@ export declare const DietCardGrid: ({ children }: {
5
5
  export declare const CareerPathCard: () => import("react/jsx-runtime").JSX.Element;
6
6
  export declare const CareerPathsPanel: () => import("react/jsx-runtime").JSX.Element;
7
7
  export declare const SkillPathsPanel: () => import("react/jsx-runtime").JSX.Element;
8
+ export declare const getCertificationProviderLogoUrl: (fileName: string) => string;
8
9
  export declare const CertificationPathsPanel: () => import("react/jsx-runtime").JSX.Element;
9
10
  export declare const LiveLearningPanel: () => import("react/jsx-runtime").JSX.Element;
@@ -1,3 +1,4 @@
1
+ import _styled from "@emotion/styled/base";
1
2
  /* eslint-disable react/no-array-index-key */ // can be removed once we add dynamic data
2
3
  import { Anchor, Box, Card, FlexBox, GridBox, Text } from '@codecademy/gamut';
3
4
  import { LevelIcon } from '@codecademy/gamut-icons';
@@ -8,6 +9,7 @@ import { liveLearningHubItems, topLanguages } from '../../../lib/catalogList';
8
9
  import { AppHeaderDietCard } from '../AppHeaderDietCard';
9
10
  import { useAppHeaderSectionContext } from '../AppHeaderSection/AppHeaderSectionContext';
10
11
  import { PanelLayout } from '../AppHeaderSection/PanelLayout';
12
+ import { CERTIFICATION_PROVIDERS } from './consts';
11
13
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
12
14
  export const CourseTopicsPanel = () => {
13
15
  const {
@@ -129,22 +131,95 @@ export const SkillPathsPanel = () => {
129
131
  })
130
132
  });
131
133
  };
134
+ export const getCertificationProviderLogoUrl = fileName => `https://static-assets.codecademy.com/assets/certification-provider-logos/catalog-dropdown/v1/${fileName}`;
135
+ const Image = Box.withComponent('img', {
136
+ target: "eqfnvo1",
137
+ label: "Image"
138
+ });
139
+ const GrayscaleToColorHoverCard = /*#__PURE__*/_styled(Card, {
140
+ target: "eqfnvo0",
141
+ label: "GrayscaleToColorHoverCard"
142
+ })("filter:grayscale(1);img{filter:", ({
143
+ overrideImgFilters
144
+ }) => overrideImgFilters ? 'contrast(5)' : 'brightness(0.25)', ";}transition:filter 0.2s ease-in-out;&:hover{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    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
+ const ProviderChip = ({
146
+ name,
147
+ href,
148
+ imgSrc,
149
+ tabIndex
150
+ }) => {
151
+ return /*#__PURE__*/_jsx(Anchor, {
152
+ href: href,
153
+ variant: "interface",
154
+ tabIndex: tabIndex,
155
+ width: "100%",
156
+ height: "100%",
157
+ display: "block",
158
+ children: /*#__PURE__*/_jsx(GrayscaleToColorHoverCard, {
159
+ borderColor: "border-tertiary",
160
+ borderRadius: "lg",
161
+ isInteractive: true,
162
+ width: "100%",
163
+ height: "100%",
164
+ p: 8,
165
+ overrideImgFilters: name.toLowerCase() === 'kubernetes',
166
+ children: /*#__PURE__*/_jsx(Image, {
167
+ src: imgSrc,
168
+ alt: name,
169
+ display: "block",
170
+ m: "auto",
171
+ height: 52
172
+ })
173
+ })
174
+ }, name);
175
+ };
132
176
  export const CertificationPathsPanel = () => {
133
- return /*#__PURE__*/_jsx(PanelLayout, {
177
+ const {
178
+ tabIndex
179
+ } = useAppHeaderSectionContext();
180
+ return /*#__PURE__*/_jsxs(PanelLayout, {
134
181
  heading: "Certification paths",
135
- description: "Get ready for certification exams with guided learning paths.",
182
+ 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.",
136
183
  linkItem: {
137
184
  type: 'link',
138
- href: '/catalog?type=certification-path',
139
- text: 'View all certification paths',
185
+ href: '/catalog/certification-prep',
186
+ text: 'Explore all certification paths',
140
187
  trackingTarget: 'catalog-header-view-all-certification-paths',
141
188
  id: 'view-all-certification-paths'
142
189
  },
143
- children: /*#__PURE__*/_jsx(DietCardGrid, {
144
- children: Array.from({
145
- length: 6
146
- }).map((_, index) => /*#__PURE__*/_jsx(CareerPathCard, {}, `${index}-card`))
147
- })
190
+ children: [/*#__PURE__*/_jsx(Text, {
191
+ as: "h3",
192
+ fontSize: 18,
193
+ fontWeight: "bold",
194
+ children: "Providers"
195
+ }), /*#__PURE__*/_jsx(GridBox, {
196
+ gridTemplateColumns: {
197
+ _: '1fr',
198
+ xs: 'repeat(2, 1fr)',
199
+ sm: 'repeat(3, 1fr)',
200
+ md: 'repeat(4, 1fr)'
201
+ },
202
+ gap: 16,
203
+ width: "100%",
204
+ as: "ul",
205
+ listStyle: "none",
206
+ p: 0,
207
+ m: 0,
208
+ children: CERTIFICATION_PROVIDERS.map(({
209
+ name,
210
+ logoUrl,
211
+ hubType
212
+ }) => /*#__PURE__*/_jsx(Box, {
213
+ as: "li",
214
+ width: "100%",
215
+ children: /*#__PURE__*/_jsx(ProviderChip, {
216
+ name: name,
217
+ href: hubType === 'subhub' ? `/search?query=${name} certifications` : `/catalog/certification-prep?provider=${name.toLowerCase()}`,
218
+ imgSrc: logoUrl,
219
+ tabIndex: tabIndex
220
+ })
221
+ }, name))
222
+ })]
148
223
  });
149
224
  };
150
225
  export const LiveLearningPanel = () => {
@@ -11,3 +11,8 @@ export declare const bannerData: {
11
11
  text: string;
12
12
  href: string;
13
13
  };
14
+ export declare const CERTIFICATION_PROVIDERS: {
15
+ name: string;
16
+ logoUrl: string;
17
+ hubType: string;
18
+ }[];
@@ -1,5 +1,5 @@
1
1
  import { BookLibraryIcon, BriefcaseIcon, OnlineClassStudentIcon, ProfessionalCertificateIcon, StudyBookIcon } from '@codecademy/gamut-icons';
2
- import { CareerPathsPanel, CertificationPathsPanel, CourseTopicsPanel, LiveLearningPanel, SkillPathsPanel } from './NavPanels';
2
+ import { CareerPathsPanel, CertificationPathsPanel, CourseTopicsPanel, getCertificationProviderLogoUrl, LiveLearningPanel, SkillPathsPanel } from './NavPanels';
3
3
  export const CATALOG_NAV_SECTIONS = [{
4
4
  item: {
5
5
  icon: StudyBookIcon,
@@ -49,4 +49,53 @@ export const CATALOG_NAV_SECTIONS = [{
49
49
  export const bannerData = {
50
50
  text: 'Want to help shape digital products? Check out the new UX Designer career path.',
51
51
  href: '/learn/paths/ux-designer-career-path'
52
- };
52
+ };
53
+ export const CERTIFICATION_PROVIDERS = [{
54
+ name: 'Microsoft',
55
+ logoUrl: getCertificationProviderLogoUrl('microsoft.svg'),
56
+ hubType: 'subhub'
57
+ }, {
58
+ name: 'CompTIA',
59
+ logoUrl: getCertificationProviderLogoUrl('comptia.svg'),
60
+ hubType: 'subhub'
61
+ }, {
62
+ name: 'ISC2',
63
+ logoUrl: getCertificationProviderLogoUrl('isc2.svg'),
64
+ hubType: 'subhub'
65
+ }, {
66
+ name: 'AWS',
67
+ logoUrl: getCertificationProviderLogoUrl('aws.svg'),
68
+ hubType: 'subhub'
69
+ }, {
70
+ name: 'Google',
71
+ logoUrl: getCertificationProviderLogoUrl('google.svg'),
72
+ hubType: 'certification-prep'
73
+ }, {
74
+ name: 'Cisco',
75
+ logoUrl: getCertificationProviderLogoUrl('cisco.svg'),
76
+ hubType: 'certification-prep'
77
+ }, {
78
+ name: 'IIBA',
79
+ logoUrl: getCertificationProviderLogoUrl('iiba.svg'),
80
+ hubType: 'certification-prep'
81
+ }, {
82
+ name: 'ISTQB',
83
+ logoUrl: getCertificationProviderLogoUrl('istqb.svg'),
84
+ hubType: 'certification-prep'
85
+ }, {
86
+ name: 'ISACA',
87
+ logoUrl: getCertificationProviderLogoUrl('isaca.svg'),
88
+ hubType: 'certification-prep'
89
+ }, {
90
+ name: 'Kubernetes',
91
+ logoUrl: getCertificationProviderLogoUrl('kubernetes.svg'),
92
+ hubType: 'certification-prep'
93
+ }, {
94
+ name: 'Oracle',
95
+ logoUrl: getCertificationProviderLogoUrl('oracle.svg'),
96
+ hubType: 'certification-prep'
97
+ }, {
98
+ name: 'Project Management Institute',
99
+ logoUrl: getCertificationProviderLogoUrl('pmi.svg'),
100
+ hubType: 'certification-prep'
101
+ }];
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.7.0",
4
+ "version": "3.8.0-alpha.923923e1fa.0",
5
5
  "author": "Codecademy Engineering <dev@codecademy.com>",
6
6
  "dependencies": {
7
7
  "@emotion/is-prop-valid": "^1.2.1",