@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.
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.d.ts +1 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.js +84 -9
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.d.ts +5 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.js +51 -2
- package/package.json +1 -1
|
@@ -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
|
-
|
|
177
|
+
const {
|
|
178
|
+
tabIndex
|
|
179
|
+
} = useAppHeaderSectionContext();
|
|
180
|
+
return /*#__PURE__*/_jsxs(PanelLayout, {
|
|
134
181
|
heading: "Certification paths",
|
|
135
|
-
description: "
|
|
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
|
|
139
|
-
text: '
|
|
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(
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
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 = () => {
|
|
@@ -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.
|
|
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",
|