@codecademy/brand 3.16.0-alpha.c3887923ee.0 → 3.16.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.
@@ -8,7 +8,7 @@ export const RESOURCES_NAV_SECTIONS = [{
8
8
  text: 'Docs',
9
9
  id: 'docs',
10
10
  type: 'resources-dropdown',
11
- trackingTarget: 'topnav_resources_docs'
11
+ trackingTarget: 'topnav_resources_tab_docs'
12
12
  },
13
13
  panel: DocsPanel
14
14
  }, {
@@ -17,7 +17,7 @@ export const RESOURCES_NAV_SECTIONS = [{
17
17
  text: 'Learning tools',
18
18
  id: 'learning-tools',
19
19
  type: 'resources-dropdown',
20
- trackingTarget: 'topnav_resources_learning_tools'
20
+ trackingTarget: 'topnav_resources_tab_learning_tools'
21
21
  },
22
22
  panel: LearningToolsPanel
23
23
  }, {
@@ -26,7 +26,7 @@ export const RESOURCES_NAV_SECTIONS = [{
26
26
  text: 'Practice tools',
27
27
  id: 'practice-tools',
28
28
  type: 'resources-dropdown',
29
- trackingTarget: 'topnav_resources_practice_tools'
29
+ trackingTarget: 'topnav_resources_tab_practice_tools'
30
30
  },
31
31
  panel: PracticeToolsPanel
32
32
  }, {
@@ -35,7 +35,7 @@ export const RESOURCES_NAV_SECTIONS = [{
35
35
  text: 'Inspiration',
36
36
  id: 'inspiration',
37
37
  type: 'resources-dropdown',
38
- trackingTarget: 'topnav_resources_inspiration'
38
+ trackingTarget: 'topnav_resources_tab_inspiration'
39
39
  },
40
40
  panel: InspirationPanel
41
41
  }];
@@ -170,7 +170,7 @@ export const learningToolsLinks = [{
170
170
  linkItem: {
171
171
  id: 'articles',
172
172
  href: '/articles',
173
- trackingTarget: 'topnav_resources_articles',
173
+ trackingTarget: 'topnav_resources_learning_articles',
174
174
  text: 'Articles',
175
175
  type: 'link'
176
176
  },
@@ -180,7 +180,7 @@ export const learningToolsLinks = [{
180
180
  linkItem: {
181
181
  id: 'cheatsheets',
182
182
  href: '/resources/cheatsheets/all',
183
- trackingTarget: 'topnav_resources_cheatsheets',
183
+ trackingTarget: 'topnav_resources_learning_cheatsheets',
184
184
  text: 'Cheatsheets',
185
185
  type: 'link'
186
186
  },
@@ -190,7 +190,7 @@ export const learningToolsLinks = [{
190
190
  linkItem: {
191
191
  id: 'videos',
192
192
  href: '/resources/videos',
193
- trackingTarget: 'topnav_resources_videos',
193
+ trackingTarget: 'topnav_resources_learning_videos',
194
194
  text: 'Videos',
195
195
  type: 'link'
196
196
  },
@@ -200,7 +200,7 @@ export const learningToolsLinks = [{
200
200
  linkItem: {
201
201
  id: 'projects',
202
202
  href: '/projects',
203
- trackingTarget: 'topnav_resources_projects',
203
+ trackingTarget: 'topnav_resources_learning_projects',
204
204
  text: 'Projects',
205
205
  type: 'link'
206
206
  },
@@ -211,8 +211,8 @@ export const practiceToolsLinks = [{
211
211
  linkItem: {
212
212
  id: 'code-challenges',
213
213
  href: '/code-challenges',
214
- trackingTarget: 'topnav_resources_code_challenges',
215
- text: 'Code Challenges',
214
+ trackingTarget: 'topnav_resources_learning_code_challenges',
215
+ text: 'Code challenges',
216
216
  type: 'link'
217
217
  },
218
218
  icon: /*#__PURE__*/_jsx(ProgrammingBrowserIcon, {}),
@@ -221,7 +221,7 @@ export const practiceToolsLinks = [{
221
221
  linkItem: {
222
222
  id: 'workspaces',
223
223
  href: '/pages/workspaces',
224
- trackingTarget: 'topnav_resources_workspaces',
224
+ trackingTarget: 'topnav_resources_learning_workspaces',
225
225
  text: 'Workspaces',
226
226
  type: 'link'
227
227
  },
@@ -231,8 +231,8 @@ export const practiceToolsLinks = [{
231
231
  linkItem: {
232
232
  id: 'job-readiness',
233
233
  href: '/job-readiness',
234
- trackingTarget: 'topnav_resources_job_readiness',
235
- text: 'Job-Readiness Checker',
234
+ trackingTarget: 'topnav_resources_learning_job_readiness',
235
+ text: 'Job-readiness checker',
236
236
  type: 'link'
237
237
  },
238
238
  icon: /*#__PURE__*/_jsx(PeopleIcon, {}),
@@ -241,7 +241,7 @@ export const practiceToolsLinks = [{
241
241
  linkItem: {
242
242
  id: 'interview-simulator',
243
243
  href: '/interview-simulator',
244
- trackingTarget: 'topnav_resources_interview_simulator',
244
+ trackingTarget: 'topnav_resources_learning_interview_simulator',
245
245
  text: 'Interview Simulator',
246
246
  type: 'link'
247
247
  },
@@ -252,7 +252,7 @@ export const inspirationLinks = [{
252
252
  linkItem: {
253
253
  id: 'learner-stories',
254
254
  href: '/resources/blog/category/get-inspired',
255
- trackingTarget: 'topnav_resources_learner_stories',
255
+ trackingTarget: 'topnav_resources_inspiration_learner_stories',
256
256
  text: 'Learner stories',
257
257
  type: 'link'
258
258
  },
@@ -262,8 +262,8 @@ export const inspirationLinks = [{
262
262
  linkItem: {
263
263
  id: 'learning-tips',
264
264
  href: '/resources/blog/category/learning-tips',
265
- trackingTarget: 'topnav_resources_learning_tips',
266
- text: 'Learning Tips',
265
+ trackingTarget: 'topnav_resources_inspiration_learning_tips',
266
+ text: 'Learning tips',
267
267
  type: 'link'
268
268
  },
269
269
  icon: /*#__PURE__*/_jsx(InfoCircleIcon, {}),
@@ -272,8 +272,8 @@ export const inspirationLinks = [{
272
272
  linkItem: {
273
273
  id: 'career-advice',
274
274
  href: '/resources/blog/category/career',
275
- trackingTarget: 'topnav_resources_career_advice',
276
- text: 'Career Advice',
275
+ trackingTarget: 'topnav_resources_inspiration_career_advice',
276
+ text: 'Career advice',
277
277
  type: 'link'
278
278
  },
279
279
  icon: /*#__PURE__*/_jsx(BriefcaseIcon, {}),
@@ -282,8 +282,8 @@ export const inspirationLinks = [{
282
282
  linkItem: {
283
283
  id: 'finding-a-job',
284
284
  href: '/resources/blog/category/finding-a-job',
285
- trackingTarget: 'topnav_resources_finding_a_job',
286
- text: 'Finding a Job',
285
+ trackingTarget: 'topnav_resources_inspiration_finding_a_job',
286
+ text: 'Finding a job',
287
287
  type: 'link'
288
288
  },
289
289
  icon: /*#__PURE__*/_jsx(SearchIcon, {}),
@@ -3,6 +3,7 @@ import { ColorMode } from '@codecademy/gamut-styles';
3
3
  import { useCallback, useContext, useEffect, useRef, useState } from 'react';
4
4
  import * as React from 'react';
5
5
  import { GlobalNavRedesignContext } from '../../../GlobalHeader';
6
+ import { DropdownPositions, useHeaderDisplayContext } from '../../../GlobalHeader/context';
6
7
  import { getHeaderResourcesList } from '../../../lib/resourcesList';
7
8
  import { AnimatedMegaMenuDropdown } from '../../shared';
8
9
  import { AppHeaderDropdownProvider } from '../AppHeaderDropdownProvider';
@@ -13,15 +14,25 @@ import { AppHeaderSection } from '../AppHeaderSection';
13
14
  import { RESOURCES_NAV_SECTIONS } from './consts';
14
15
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
15
16
  const StyledAnimatedMegaMenuDropdown = /*#__PURE__*/_styled(AnimatedMegaMenuDropdown, {
17
+ // prevent the isAnon and displayGlobalNavRedesign props from being passed to the DOM element, which would cause a React warning.
18
+ shouldForwardProp: prop => prop !== 'isAnon' && prop !== 'displayGlobalNavRedesign' && prop !== 'narrowResourceDropdownPosition' && prop !== 'wideResourceDropdownPosition',
16
19
  target: "ekdg1bw0",
17
20
  label: "StyledAnimatedMegaMenuDropdown"
18
21
  })("left:", ({
19
22
  isAnon,
20
- displayGlobalNavRedesign
21
- }) => displayGlobalNavRedesign ? '-9.5rem' : isAnon ? '-14.5rem' : '-19.5rem', ";@media (min-width: 1261px){left:", ({
23
+ displayGlobalNavRedesign,
24
+ narrowResourceDropdownPosition
25
+ }) => {
26
+ if (displayGlobalNavRedesign) return narrowResourceDropdownPosition;
27
+ return isAnon ? '-14.5rem' : '-19.5rem';
28
+ }, ";@media (min-width: 1261px){left:", ({
22
29
  isAnon,
23
- displayGlobalNavRedesign
24
- }) => displayGlobalNavRedesign ? '-15rem' : isAnon ? '-14.5rem' : '-19.5rem', ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyUmVzb3VyY2VzRHJvcGRvd24vaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCRSIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlclJlc291cmNlc0Ryb3Bkb3duL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbG9yTW9kZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBHbG9iYWxOYXZSZWRlc2lnbkNvbnRleHQgfSBmcm9tICcuLi8uLi8uLi9HbG9iYWxIZWFkZXInO1xuaW1wb3J0IHsgZ2V0SGVhZGVyUmVzb3VyY2VzTGlzdCB9IGZyb20gJy4uLy4uLy4uL2xpYi9yZXNvdXJjZXNMaXN0JztcbmltcG9ydCB7XG4gIEFuaW1hdGVkTWVnYU1lbnVEcm9wZG93bixcbiAgQXBwSGVhZGVyQWN0aW9uLFxuICBBcHBIZWFkZXJSZXNvdXJjZXNEcm9wZG93bkl0ZW0sXG59IGZyb20gJy4uLy4uL3NoYXJlZCc7XG5pbXBvcnQgeyBBcHBIZWFkZXJEcm9wZG93blByb3ZpZGVyIH0gZnJvbSAnLi4vQXBwSGVhZGVyRHJvcGRvd25Qcm92aWRlcic7XG5pbXBvcnQgeyBBcHBIZWFkZXJEcm9wZG93bk5hdkJ1dHRvbiB9IGZyb20gJy4uL0FwcEhlYWRlck5hdkJ1dHRvbi9BcHBIZWFkZXJEcm9wZG93bk5hdkJ1dHRvbic7XG5pbXBvcnQgeyB1c2VBcHBIZWFkZXJDb250ZXh0IH0gZnJvbSAnLi4vQXBwSGVhZGVyUHJvdmlkZXInO1xuaW1wb3J0IHsgQXBwSGVhZGVyUmVzb3VyY2VzU2VjdGlvbiB9IGZyb20gJy4uL0FwcEhlYWRlclJlc291cmNlc1NlY3Rpb24nO1xuaW1wb3J0IHsgQXBwSGVhZGVyU2VjdGlvbiB9IGZyb20gJy4uL0FwcEhlYWRlclNlY3Rpb24nO1xuaW1wb3J0IHsgUkVTT1VSQ0VTX05BVl9TRUNUSU9OUyB9IGZyb20gJy4vY29uc3RzJztcblxuZXhwb3J0IHR5cGUgQXBwSGVhZGVyUmVzb3VyY2VEcm9wZG93blByb3BzID0gQXBwSGVhZGVyQWN0aW9uICYge1xuICBpdGVtOiBBcHBIZWFkZXJSZXNvdXJjZXNEcm9wZG93bkl0ZW07XG4gIGlzQW5vbjogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZEFuaW1hdGVkTWVnYU1lbnVEcm9wZG93biA9IHN0eWxlZChBbmltYXRlZE1lZ2FNZW51RHJvcGRvd24pPHtcbiAgaXNBbm9uOiBib29sZWFuO1xuICBkaXNwbGF5R2xvYmFsTmF2UmVkZXNpZ246IGJvb2xlYW47XG59PmBcbiAgbGVmdDogJHsoeyBpc0Fub24sIGRpc3BsYXlHbG9iYWxOYXZSZWRlc2lnbiB9KSA9PlxuICAgIGRpc3BsYXlHbG9iYWxOYXZSZWRlc2lnbiA/ICctOS41cmVtJyA6IGlzQW5vbiA/ICctMTQuNXJlbScgOiAnLTE5LjVyZW0nfTtcblxuICBAbWVkaWEgKG1pbi13aWR0aDogMTI2MXB4KSB7XG4gICAgbGVmdDogJHsoeyBpc0Fub24sIGRpc3BsYXlHbG9iYWxOYXZSZWRlc2lnbiB9KSA9PlxuICAgICAgZGlzcGxheUdsb2JhbE5hdlJlZGVzaWduID8gJy0xNXJlbScgOiBpc0Fub24gPyAnLTE0LjVyZW0nIDogJy0xOS41cmVtJ307XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBBcHBIZWFkZXJSZXNvdXJjZXNEcm9wZG93bjogUmVhY3QuRkM8XG4gIEFwcEhlYWRlclJlc291cmNlRHJvcGRvd25Qcm9wc1xuPiA9ICh7IGFjdGlvbiwgaXRlbSwgaXNBbm9uIH0pID0+IHtcbiAgY29uc3QgeyB0ZXh0IH0gPSBpdGVtO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQgfCBudWxsPihudWxsKTtcbiAgY29uc3QgYnV0dG9uUmVmID0gdXNlUmVmPEhUTUxCdXR0b25FbGVtZW50PihudWxsKTtcbiAgY29uc3QgZHJvcGRvd25SZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQgfCBudWxsPihudWxsKTtcbiAgY29uc3QgW2lzT3Blbiwgc2V0SXNPcGVuXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBsYXN0T3BlbmVkRHJvcGRvd24sIHNldExhc3RPcGVuZWREcm9wZG93biB9ID0gdXNlQXBwSGVhZGVyQ29udGV4dCgpO1xuXG4gIC8vIEFkZCBzY3JvbGxiYXIgZm9yIHNob3J0IHNjcmVlbnMgYWZ0ZXIgdHJhbnNpdGlvbiAob3RoZXJ3aXNlIHNjcm9sbGJhciBhcHBlYXJzIGFuZCBkaXNzYXBlYXJzIGZvciBhZGVxdWF0ZSBoZWlnaHRzIGR1cmluZyB0cmFuc2l0aW9uKVxuICBjb25zdCBbYW5pbWF0aW9uQ29tcGxldGVTdHlsZXMsIHNldEFuaW1hdGlvbkNvbXBsZXRlU3R5bGVzXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICBjb25zdCBoZWFkZXJSZXNvdXJjZXNMaXN0ID0gZ2V0SGVhZGVyUmVzb3VyY2VzTGlzdCgpO1xuXG4gIGNvbnN0IGFuaW1hdGlvbkZpbmlzaGVkID0gKCkgPT4ge1xuICAgIHNldEFuaW1hdGlvbkNvbXBsZXRlU3R5bGVzKGlzT3Blbik7XG4gICAgaWYgKGlzT3BlbiAmJiBkcm9wZG93blJlZi5jdXJyZW50KSB7XG4gICAgICBkcm9wZG93blJlZi5jdXJyZW50LnNjcm9sbFRvcCA9IDA7XG4gICAgfVxuICB9O1xuXG4gIGNvbnN0IHRvZ2dsZUlzT3BlbiA9ICgpID0+IHNldElzT3BlbigocHJldikgPT4gIXByZXYpO1xuXG4gIGNvbnN0IGhhbmRsZU9uQ2xpY2sgPSAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHtcbiAgICB0b2dnbGVJc09wZW4oKTtcbiAgICBpZiAoIWlzT3Blbikge1xuICAgICAgYWN0aW9uKGV2ZW50LCBpdGVtKTtcbiAgICAgIGlmIChzZXRMYXN0T3BlbmVkRHJvcGRvd24pIHtcbiAgICAgICAgc2V0TGFzdE9wZW5lZERyb3Bkb3duKHRleHQpO1xuICAgICAgfVxuICAgIH1cbiAgfTtcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRJc09wZW4oZmFsc2UpO1xuICAgIGJ1dHRvblJlZj8uY3VycmVudD8uZm9jdXMoKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGxhc3RPcGVuZWREcm9wZG93biAhPT0gdGV4dCAmJiBpc09wZW4pIHtcbiAgICAgIHNldElzT3BlbihmYWxzZSk7XG4gICAgfVxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC1ob29rcy9leGhhdXN0aXZlLWRlcHNcbiAgfSwgW2xhc3RPcGVuZWREcm9wZG93bl0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgZnVuY3Rpb24gaGFuZGxlQ2xpY2tPdXRzaWRlKGV2ZW50OiBNb3VzZUV2ZW50IHwgRXZlbnQpIHtcbiAgICAgIGNvbnN0IGNvbnRhaW5lciA9IGNvbnRhaW5lclJlZj8uY3VycmVudDtcbiAgICAgIGNvbnN0IGJ1dHRvbiA9IGJ1dHRvblJlZj8uY3VycmVudDtcbiAgICAgIGlmIChcbiAgICAgICAgaXNPcGVuICYmXG4gICAgICAgIGNvbnRhaW5lciAmJlxuICAgICAgICAhY29udGFpbmVyLmNvbnRhaW5zKGV2ZW50LnRhcmdldCBhcyBOb2RlKSAmJlxuICAgICAgICBidXR0b24gJiZcbiAgICAgICAgIWJ1dHRvbi5jb250YWlucyhldmVudC50YXJnZXQgYXMgTm9kZSlcbiAgICAgICkge1xuICAgICAgICBoYW5kbGVDbG9zZSgpO1xuICAgICAgfVxuICAgIH1cblxuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNlZG93bicsIGhhbmRsZUNsaWNrT3V0c2lkZSk7XG4gICAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignYmx1cicsIGhhbmRsZUNsaWNrT3V0c2lkZSk7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ21vdXNlZG93bicsIGhhbmRsZUNsaWNrT3V0c2lkZSk7XG4gICAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdibHVyJywgaGFuZGxlQ2xpY2tPdXRzaWRlKTtcbiAgICB9O1xuICB9LCBbY29udGFpbmVyUmVmLCBoYW5kbGVDbG9zZSwgaXNPcGVuXSk7XG5cbiAgY29uc3QgZGlzcGxheUdsb2JhbE5hdlJlZGVzaWduID0gdXNlQ29udGV4dChHbG9iYWxOYXZSZWRlc2lnbkNvbnRleHQpO1xuXG4gIHJldHVybiAoXG4gICAgPEFwcEhlYWRlckRyb3Bkb3duUHJvdmlkZXIgaGFuZGxlQ2xvc2U9e2hhbmRsZUNsb3NlfT5cbiAgICAgIDxBcHBIZWFkZXJEcm9wZG93bk5hdkJ1dHRvblxuICAgICAgICBidXR0b25SZWY9e2J1dHRvblJlZn1cbiAgICAgICAgaGFuZGxlT25DbGljaz17aGFuZGxlT25DbGlja31cbiAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgIHRpdGxlPXt0ZXh0fVxuICAgICAgLz5cbiAgICAgIDxTdHlsZWRBbmltYXRlZE1lZ2FNZW51RHJvcGRvd25cbiAgICAgICAgaXNBbm9uPXtpc0Fub259XG4gICAgICAgIGRpc3BsYXlHbG9iYWxOYXZSZWRlc2lnbj17ZGlzcGxheUdsb2JhbE5hdlJlZGVzaWdufVxuICAgICAgICB0YWJJbmRleD17LTF9IC8vIHByZXZlbnQgZnJvbSBpbnRlcmZlcmluZyB3aXRoIEFwcEhlYWRlciBmb2N1cyBsb2dpY1xuICAgICAgICByZWY9e2Ryb3Bkb3duUmVmfVxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIHRvcDogJzMuNXJlbScsXG4gICAgICAgICAgbWluV2lkdGg6ICc2NHJlbScsXG4gICAgICAgICAgb3ZlcmZsb3dZOiAnYXV0bycsXG4gICAgICAgICAgbWF4SGVpZ2h0OiBhbmltYXRpb25Db21wbGV0ZVN0eWxlcyA/ICc4NXZoJyA6IDAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBkaXNwbGF5R2xvYmFsTmF2UmVkZXNpZ24gPyAndHJhbnNwYXJlbnQnIDogJycsXG4gICAgICAgIH19XG4gICAgICAgIGluaXRpYWw9e3sgYm9yZGVyV2lkdGg6IDAsIGhlaWdodDogMCB9fVxuICAgICAgICBhbmltYXRlPXt7XG4gICAgICAgICAgYm9yZGVyV2lkdGg6IGlzT3BlbiA/IChkaXNwbGF5R2xvYmFsTmF2UmVkZXNpZ24gPyAwIDogMSkgOiAwLFxuICAgICAgICAgIGhlaWdodDogaXNPcGVuID8gJ2ZpdC1jb250ZW50JyA6IDAsXG4gICAgICAgIH19XG4gICAgICAgIHRyYW5zaXRpb249e3sgZHVyYXRpb246IDAuMTc1IH19XG4gICAgICAgIGFyaWEtaGlkZGVuPXshaXNPcGVufVxuICAgICAgICBkYXRhLXRlc3RpZD1cInJlc291cmNlcy1tZW51LWRyb3Bkb3duXCJcbiAgICAgICAgb25BbmltYXRpb25Db21wbGV0ZT17YW5pbWF0aW9uRmluaXNoZWR9XG4gICAgICA+XG4gICAgICAgIHtkaXNwbGF5R2xvYmFsTmF2UmVkZXNpZ24gPyAoXG4gICAgICAgICAgPENvbG9yTW9kZSBtb2RlPVwibGlnaHRcIj5cbiAgICAgICAgICAgIDxBcHBIZWFkZXJTZWN0aW9uXG4gICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICByZWY9e2NvbnRhaW5lclJlZn1cbiAgICAgICAgICAgICAgbmF2U2VjdGlvbnM9e1JFU09VUkNFU19OQVZfU0VDVElPTlN9XG4gICAgICAgICAgICAgIGhhbmRsZUNsb3NlPXsoKSA9PiBzZXRJc09wZW4oZmFsc2UpfVxuICAgICAgICAgICAgICB0eXBlPVwicmVzb3VyY2VzLWRyb3Bkb3duXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9Db2xvck1vZGU+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPEFwcEhlYWRlclJlc291cmNlc1NlY3Rpb25cbiAgICAgICAgICAgIGFjdGlvbj17YWN0aW9ufVxuICAgICAgICAgICAgcmVmPXtjb250YWluZXJSZWZ9XG4gICAgICAgICAgICBpZD17YG1lbnUtY29udGFpbmVyJHtpdGVtLnRleHR9YH1cbiAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgaGFuZGxlQ2xvc2U9eygpID0+IHNldElzT3BlbihmYWxzZSl9XG4gICAgICAgICAgICByZXNvdXJjZXM9e2hlYWRlclJlc291cmNlc0xpc3R9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgIDwvU3R5bGVkQW5pbWF0ZWRNZWdhTWVudURyb3Bkb3duPlxuICAgIDwvQXBwSGVhZGVyRHJvcGRvd25Qcm92aWRlcj5cbiAgKTtcbn07XG4iXX0= */"));
30
+ displayGlobalNavRedesign,
31
+ wideResourceDropdownPosition
32
+ }) => {
33
+ if (displayGlobalNavRedesign) return wideResourceDropdownPosition;
34
+ return isAnon ? '-14.5rem' : '-19.5rem';
35
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/index.tsx"],"names":[],"mappings":"AAwCE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/index.tsx","sourcesContent":["import { ColorMode } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useCallback, useContext, useEffect, useRef, useState } from 'react';\nimport * as React from 'react';\n\nimport { GlobalNavRedesignContext } from '../../../GlobalHeader';\nimport {\n  DropdownPositions,\n  useHeaderDisplayContext,\n} from '../../../GlobalHeader/context';\nimport { getHeaderResourcesList } from '../../../lib/resourcesList';\nimport {\n  AnimatedMegaMenuDropdown,\n  AppHeaderAction,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownProvider } from '../AppHeaderDropdownProvider';\nimport { AppHeaderDropdownNavButton } from '../AppHeaderNavButton/AppHeaderDropdownNavButton';\nimport { useAppHeaderContext } from '../AppHeaderProvider';\nimport { AppHeaderResourcesSection } from '../AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../AppHeaderSection';\nimport { RESOURCES_NAV_SECTIONS } from './consts';\n\nexport type AppHeaderResourceDropdownProps = AppHeaderAction & {\n  item: AppHeaderResourcesDropdownItem;\n  isAnon: boolean;\n};\n\nconst StyledAnimatedMegaMenuDropdown = styled(AnimatedMegaMenuDropdown, {\n  // prevent the isAnon and displayGlobalNavRedesign props from being passed to the DOM element, which would cause a React warning.\n  shouldForwardProp: (prop) =>\n    prop !== 'isAnon' &&\n    prop !== 'displayGlobalNavRedesign' &&\n    prop !== 'narrowResourceDropdownPosition' &&\n    prop !== 'wideResourceDropdownPosition',\n})<{\n  isAnon: boolean;\n  displayGlobalNavRedesign: boolean;\n  narrowResourceDropdownPosition: string;\n  wideResourceDropdownPosition: string;\n}>`\n  left: ${({\n    isAnon,\n    displayGlobalNavRedesign,\n    narrowResourceDropdownPosition,\n  }) => {\n    if (displayGlobalNavRedesign) return narrowResourceDropdownPosition;\n    return isAnon ? '-14.5rem' : '-19.5rem';\n  }};\n\n  @media (min-width: 1261px) {\n    left: ${({\n      isAnon,\n      displayGlobalNavRedesign,\n      wideResourceDropdownPosition,\n    }) => {\n      if (displayGlobalNavRedesign) return wideResourceDropdownPosition;\n      return isAnon ? '-14.5rem' : '-19.5rem';\n    }};\n  }\n`;\n\nexport const AppHeaderResourcesDropdown: React.FC<\n  AppHeaderResourceDropdownProps\n> = ({ action, item, isAnon }) => {\n  const { text } = item;\n  const containerRef = useRef<HTMLDivElement | null>(null);\n  const buttonRef = useRef<HTMLButtonElement>(null);\n  const dropdownRef = useRef<HTMLDivElement | null>(null);\n  const [isOpen, setIsOpen] = useState(false);\n  const { lastOpenedDropdown, setLastOpenedDropdown } = useAppHeaderContext();\n  const { headerType } = useHeaderDisplayContext();\n  const { resourceDropdown } = DropdownPositions[headerType];\n  const narrowResourceDropdownPosition = resourceDropdown.narrow;\n  const wideResourceDropdownPosition = resourceDropdown.wide;\n\n  // Add scrollbar for short screens after transition (otherwise scrollbar appears and dissapears for adequate heights during transition)\n  const [animationCompleteStyles, setAnimationCompleteStyles] = useState(false);\n\n  const headerResourcesList = getHeaderResourcesList();\n\n  const animationFinished = () => {\n    setAnimationCompleteStyles(isOpen);\n    if (isOpen && dropdownRef.current) {\n      dropdownRef.current.scrollTop = 0;\n    }\n  };\n\n  const toggleIsOpen = () => setIsOpen((prev) => !prev);\n\n  const handleOnClick = (event: React.MouseEvent) => {\n    toggleIsOpen();\n    if (!isOpen) {\n      action(event, item);\n      if (setLastOpenedDropdown) {\n        setLastOpenedDropdown(text);\n      }\n    }\n  };\n\n  const handleClose = useCallback(() => {\n    setIsOpen(false);\n    buttonRef?.current?.focus();\n  }, []);\n\n  useEffect(() => {\n    if (lastOpenedDropdown !== text && isOpen) {\n      setIsOpen(false);\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [lastOpenedDropdown]);\n\n  useEffect(() => {\n    function handleClickOutside(event: MouseEvent | Event) {\n      const container = containerRef?.current;\n      const button = buttonRef?.current;\n      if (\n        isOpen &&\n        container &&\n        !container.contains(event.target as Node) &&\n        button &&\n        !button.contains(event.target as Node)\n      ) {\n        handleClose();\n      }\n    }\n\n    document.addEventListener('mousedown', handleClickOutside);\n    document.addEventListener('blur', handleClickOutside);\n    return () => {\n      document.removeEventListener('mousedown', handleClickOutside);\n      document.removeEventListener('blur', handleClickOutside);\n    };\n  }, [containerRef, handleClose, isOpen]);\n\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  return (\n    <AppHeaderDropdownProvider handleClose={handleClose}>\n      <AppHeaderDropdownNavButton\n        buttonRef={buttonRef}\n        handleOnClick={handleOnClick}\n        isOpen={isOpen}\n        title={text}\n      />\n      <StyledAnimatedMegaMenuDropdown\n        isAnon={isAnon}\n        displayGlobalNavRedesign={displayGlobalNavRedesign}\n        narrowResourceDropdownPosition={narrowResourceDropdownPosition}\n        wideResourceDropdownPosition={wideResourceDropdownPosition}\n        tabIndex={-1} // prevent from interfering with AppHeader focus logic\n        ref={dropdownRef}\n        style={{\n          top: '3.5rem',\n          minWidth: '64rem',\n          overflowY: 'auto',\n          maxHeight: animationCompleteStyles ? '85vh' : 0,\n          backgroundColor: displayGlobalNavRedesign ? 'transparent' : '',\n        }}\n        initial={{ borderWidth: 0, height: 0 }}\n        animate={{\n          borderWidth: isOpen ? (displayGlobalNavRedesign ? 0 : 1) : 0,\n          height: isOpen ? 'fit-content' : 0,\n        }}\n        transition={{ duration: 0.175 }}\n        aria-hidden={!isOpen}\n        data-testid=\"resources-menu-dropdown\"\n        onAnimationComplete={animationFinished}\n      >\n        {displayGlobalNavRedesign ? (\n          <ColorMode mode=\"light\">\n            <AppHeaderSection\n              isOpen={isOpen}\n              ref={containerRef}\n              navSections={RESOURCES_NAV_SECTIONS}\n              handleClose={() => setIsOpen(false)}\n              type=\"resources-dropdown\"\n            />\n          </ColorMode>\n        ) : (\n          <AppHeaderResourcesSection\n            action={action}\n            ref={containerRef}\n            id={`menu-container${item.text}`}\n            isOpen={isOpen}\n            handleClose={() => setIsOpen(false)}\n            resources={headerResourcesList}\n          />\n        )}\n      </StyledAnimatedMegaMenuDropdown>\n    </AppHeaderDropdownProvider>\n  );\n};\n"]} */"));
25
36
  export const AppHeaderResourcesDropdown = ({
26
37
  action,
27
38
  item,
@@ -38,6 +49,14 @@ export const AppHeaderResourcesDropdown = ({
38
49
  lastOpenedDropdown,
39
50
  setLastOpenedDropdown
40
51
  } = useAppHeaderContext();
52
+ const {
53
+ headerType
54
+ } = useHeaderDisplayContext();
55
+ const {
56
+ resourceDropdown
57
+ } = DropdownPositions[headerType];
58
+ const narrowResourceDropdownPosition = resourceDropdown.narrow;
59
+ const wideResourceDropdownPosition = resourceDropdown.wide;
41
60
 
42
61
  // Add scrollbar for short screens after transition (otherwise scrollbar appears and dissapears for adequate heights during transition)
43
62
  const [animationCompleteStyles, setAnimationCompleteStyles] = useState(false);
@@ -94,6 +113,8 @@ export const AppHeaderResourcesDropdown = ({
94
113
  }), /*#__PURE__*/_jsx(StyledAnimatedMegaMenuDropdown, {
95
114
  isAnon: isAnon,
96
115
  displayGlobalNavRedesign: displayGlobalNavRedesign,
116
+ narrowResourceDropdownPosition: narrowResourceDropdownPosition,
117
+ wideResourceDropdownPosition: wideResourceDropdownPosition,
97
118
  tabIndex: -1 // prevent from interfering with AppHeader focus logic
98
119
  ,
99
120
  ref: dropdownRef,
@@ -3,8 +3,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
3
3
  import { Anchor, FlexBox, Text, TextButton } from '@codecademy/gamut';
4
4
  import { MiniArrowRightIcon, SupportIcon } from '@codecademy/gamut-icons';
5
5
  import { theme } from '@codecademy/gamut-styles';
6
- import { useContext } from 'react';
7
- import { HeaderQuizContext } from '../../GlobalHeader';
6
+ import { useHeaderDisplayContext } from '../../GlobalHeader/context';
8
7
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
9
8
  export const BoldSupportIcon = /*#__PURE__*/_styled(SupportIcon, {
10
9
  target: "em954zc0",
@@ -14,7 +13,7 @@ export const BoldSupportIcon = /*#__PURE__*/_styled(SupportIcon, {
14
13
  styles: "path{stroke-width:2.5;}circle{stroke-width:2.5;}"
15
14
  } : {
16
15
  name: "jcs9cn",
17
- styles: "path{stroke-width:2.5;}circle{stroke-width:2.5;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvU2VhcmNoL1F1aXpBbmRIZWxwQ2VudGVyTGlua3MudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFrRCIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQXBwSGVhZGVyL1NlYXJjaC9RdWl6QW5kSGVscENlbnRlckxpbmtzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFuY2hvciwgRmxleEJveCwgVGV4dCwgVGV4dEJ1dHRvbiB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IE1pbmlBcnJvd1JpZ2h0SWNvbiwgU3VwcG9ydEljb24gfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1pY29ucyc7XG5pbXBvcnQgeyB0aGVtZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VDb250ZXh0IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBIZWFkZXJRdWl6Q29udGV4dCB9IGZyb20gJy4uLy4uL0dsb2JhbEhlYWRlcic7XG5cbmV4cG9ydCBjb25zdCBCb2xkU3VwcG9ydEljb24gPSBzdHlsZWQoU3VwcG9ydEljb24pYFxuICBwYXRoIHtcbiAgICBzdHJva2Utd2lkdGg6IDIuNTtcbiAgfVxuICBjaXJjbGUge1xuICAgIHN0cm9rZS13aWR0aDogMi41O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUXVpekFuZEhlbHBDZW50ZXJMaW5rczogUmVhY3QuRkM8e1xuICBvblRyYWNraW5nQ2xpY2s6ICh0YXJnZXQ6IHN0cmluZykgPT4gdm9pZDtcbiAgaGFuZGxlQ2xvc2VEcm9wZG93bjogKCkgPT4gdm9pZDtcbn0+ID0gKHsgb25UcmFja2luZ0NsaWNrLCBoYW5kbGVDbG9zZURyb3Bkb3duIH0pID0+IHtcbiAgY29uc3QgeyBzaG93T25ib2FyZGluZ1F1aXosIHNob3dTb3J0aW5nUXVpeiB9ID0gdXNlQ29udGV4dChIZWFkZXJRdWl6Q29udGV4dCk7XG5cbiAgY29uc3QgaXNNb2JpbGUgPSB0aGVtZS5icmVha3BvaW50cy54cyB8fCB0aGVtZS5icmVha3BvaW50cy5zbTtcblxuICBjb25zdCBxdWl6TGluayA9IHNob3dPbmJvYXJkaW5nUXVpelxuICAgID8gJy93ZWxjb21lL2ZpbmQtYS1jb3Vyc2UnXG4gICAgOiAnL2V4cGxvcmUvc29ydGluZy1xdWl6JztcblxuICBjb25zdCBzaG93UXVpeiA9IHNob3dPbmJvYXJkaW5nUXVpeiB8fCBzaG93U29ydGluZ1F1aXo7XG5cbiAgcmV0dXJuIChcbiAgICA8RmxleEJveFxuICAgICAganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCJcbiAgICAgIGFsaWduSXRlbXM9XCJjZW50ZXJcIlxuICAgICAgYm9yZGVyVG9wPXsxfVxuICAgICAgYm9yZGVyQ29sb3I9XCJib3JkZXItdGVydGlhcnlcIlxuICAgICAgcHk9ezh9XG4gICAgPlxuICAgICAgPEZsZXhCb3ggZmxleERpcmVjdGlvbj17eyBfOiAnY29sdW1uJywgbWQ6ICdyb3cnIH19PlxuICAgICAgICB7c2hvd1F1aXogJiYgKFxuICAgICAgICAgIDw+XG4gICAgICAgICAgICA8VGV4dCBmb250U2l6ZT17MTZ9IG1yPXsxMCBhcyAwfT5cbiAgICAgICAgICAgICAgTm90IHN1cmUgd2hlcmUgdG8gYmVnaW4/XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8QW5jaG9yXG4gICAgICAgICAgICAgIGhyZWY9e3F1aXpMaW5rfVxuICAgICAgICAgICAgICB2YXJpYW50PVwic3RhbmRhcmRcIlxuICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgb25UcmFja2luZ0NsaWNrKFxuICAgICAgICAgICAgICAgICAgc2hvd09uYm9hcmRpbmdRdWl6ID8gJ3NvcnRpbmdfcXVpeicgOiAnb25ib2FyZGluZ19xdWl6J1xuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgaGFuZGxlQ2xvc2VEcm9wZG93bigpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICA8RmxleEJveCBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgZ2FwPXsxMCBhcyAwfSBvdmVyZmxvdz1cInZpc2libGVcIj5cbiAgICAgICAgICAgICAgICA8VGV4dCBmb250U2l6ZT17eyBfOiAxNCwgbWQ6IDE2IH19PlRha2Ugb3VyIHF1aXo8L1RleHQ+XG4gICAgICAgICAgICAgICAgPE1pbmlBcnJvd1JpZ2h0SWNvbiBzaXplPXsxMn0gLz5cbiAgICAgICAgICAgICAgPC9GbGV4Qm94PlxuICAgICAgICAgICAgPC9BbmNob3I+XG4gICAgICAgICAgPC8+XG4gICAgICAgICl9XG4gICAgICA8L0ZsZXhCb3g+XG4gICAgICA8VGV4dEJ1dHRvblxuICAgICAgICBocmVmPVwiL2hlbHBcIlxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBvblRyYWNraW5nQ2xpY2soJ2hlbHBfY2VudGVyJyl9XG4gICAgICAgIHNpemU9e2lzTW9iaWxlID8gJ3NtYWxsJyA6ICdub3JtYWwnfVxuICAgICAgPlxuICAgICAgICA8Qm9sZFN1cHBvcnRJY29uIG1yPXs4fSBzaXplPXsxMn0gLz5cbiAgICAgICAgSGVscCBDZW50ZXJcbiAgICAgIDwvVGV4dEJ1dHRvbj5cbiAgICA8L0ZsZXhCb3g+XG4gICk7XG59O1xuIl19 */",
16
+ styles: "path{stroke-width:2.5;}circle{stroke-width:2.5;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvU2VhcmNoL1F1aXpBbmRIZWxwQ2VudGVyTGlua3MudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU9rRCIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQXBwSGVhZGVyL1NlYXJjaC9RdWl6QW5kSGVscENlbnRlckxpbmtzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFuY2hvciwgRmxleEJveCwgVGV4dCwgVGV4dEJ1dHRvbiB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IE1pbmlBcnJvd1JpZ2h0SWNvbiwgU3VwcG9ydEljb24gfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1pY29ucyc7XG5pbXBvcnQgeyB0aGVtZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IHVzZUhlYWRlckRpc3BsYXlDb250ZXh0IH0gZnJvbSAnLi4vLi4vR2xvYmFsSGVhZGVyL2NvbnRleHQnO1xuXG5leHBvcnQgY29uc3QgQm9sZFN1cHBvcnRJY29uID0gc3R5bGVkKFN1cHBvcnRJY29uKWBcbiAgcGF0aCB7XG4gICAgc3Ryb2tlLXdpZHRoOiAyLjU7XG4gIH1cbiAgY2lyY2xlIHtcbiAgICBzdHJva2Utd2lkdGg6IDIuNTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFF1aXpBbmRIZWxwQ2VudGVyTGlua3M6IFJlYWN0LkZDPHtcbiAgb25UcmFja2luZ0NsaWNrOiAodGFyZ2V0OiBzdHJpbmcpID0+IHZvaWQ7XG4gIGhhbmRsZUNsb3NlRHJvcGRvd246ICgpID0+IHZvaWQ7XG59PiA9ICh7IG9uVHJhY2tpbmdDbGljaywgaGFuZGxlQ2xvc2VEcm9wZG93biB9KSA9PiB7XG4gIGNvbnN0IHsgc2hvd09uYm9hcmRpbmdRdWl6LCBzaG93U29ydGluZ1F1aXogfSA9IHVzZUhlYWRlckRpc3BsYXlDb250ZXh0KCk7XG5cbiAgY29uc3QgaXNNb2JpbGUgPSB0aGVtZS5icmVha3BvaW50cy54cyB8fCB0aGVtZS5icmVha3BvaW50cy5zbTtcblxuICBjb25zdCBxdWl6TGluayA9IHNob3dPbmJvYXJkaW5nUXVpelxuICAgID8gJy93ZWxjb21lL2ZpbmQtYS1jb3Vyc2UnXG4gICAgOiAnL2V4cGxvcmUvc29ydGluZy1xdWl6JztcblxuICBjb25zdCBzaG93UXVpeiA9IHNob3dPbmJvYXJkaW5nUXVpeiB8fCBzaG93U29ydGluZ1F1aXo7XG5cbiAgcmV0dXJuIChcbiAgICA8RmxleEJveFxuICAgICAganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCJcbiAgICAgIGFsaWduSXRlbXM9XCJjZW50ZXJcIlxuICAgICAgYm9yZGVyVG9wPXsxfVxuICAgICAgYm9yZGVyQ29sb3I9XCJib3JkZXItdGVydGlhcnlcIlxuICAgICAgcHk9ezh9XG4gICAgPlxuICAgICAgPEZsZXhCb3ggZmxleERpcmVjdGlvbj17eyBfOiAnY29sdW1uJywgbWQ6ICdyb3cnIH19PlxuICAgICAgICB7c2hvd1F1aXogJiYgKFxuICAgICAgICAgIDw+XG4gICAgICAgICAgICA8VGV4dCBmb250U2l6ZT17MTZ9IG1yPXsxMCBhcyAwfT5cbiAgICAgICAgICAgICAgTm90IHN1cmUgd2hlcmUgdG8gYmVnaW4/XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8QW5jaG9yXG4gICAgICAgICAgICAgIGhyZWY9e3F1aXpMaW5rfVxuICAgICAgICAgICAgICB2YXJpYW50PVwic3RhbmRhcmRcIlxuICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgb25UcmFja2luZ0NsaWNrKFxuICAgICAgICAgICAgICAgICAgc2hvd09uYm9hcmRpbmdRdWl6ID8gJ3NvcnRpbmdfcXVpeicgOiAnb25ib2FyZGluZ19xdWl6J1xuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgaGFuZGxlQ2xvc2VEcm9wZG93bigpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICA8RmxleEJveCBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgZ2FwPXsxMCBhcyAwfSBvdmVyZmxvdz1cInZpc2libGVcIj5cbiAgICAgICAgICAgICAgICA8VGV4dCBmb250U2l6ZT17eyBfOiAxNCwgbWQ6IDE2IH19PlRha2Ugb3VyIHF1aXo8L1RleHQ+XG4gICAgICAgICAgICAgICAgPE1pbmlBcnJvd1JpZ2h0SWNvbiBzaXplPXsxMn0gLz5cbiAgICAgICAgICAgICAgPC9GbGV4Qm94PlxuICAgICAgICAgICAgPC9BbmNob3I+XG4gICAgICAgICAgPC8+XG4gICAgICAgICl9XG4gICAgICA8L0ZsZXhCb3g+XG4gICAgICA8VGV4dEJ1dHRvblxuICAgICAgICBocmVmPVwiL2hlbHBcIlxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBvblRyYWNraW5nQ2xpY2soJ2hlbHBfY2VudGVyJyl9XG4gICAgICAgIHNpemU9e2lzTW9iaWxlID8gJ3NtYWxsJyA6ICdub3JtYWwnfVxuICAgICAgPlxuICAgICAgICA8Qm9sZFN1cHBvcnRJY29uIG1yPXs4fSBzaXplPXsxMn0gLz5cbiAgICAgICAgSGVscCBDZW50ZXJcbiAgICAgIDwvVGV4dEJ1dHRvbj5cbiAgICA8L0ZsZXhCb3g+XG4gICk7XG59O1xuIl19 */",
18
17
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
19
18
  });
20
19
  export const QuizAndHelpCenterLinks = ({
@@ -24,7 +23,7 @@ export const QuizAndHelpCenterLinks = ({
24
23
  const {
25
24
  showOnboardingQuiz,
26
25
  showSortingQuiz
27
- } = useContext(HeaderQuizContext);
26
+ } = useHeaderDisplayContext();
28
27
  const isMobile = theme.breakpoints.xs || theme.breakpoints.sm;
29
28
  const quizLink = showOnboardingQuiz ? '/welcome/find-a-course' : '/explore/sorting-quiz';
30
29
  const showQuiz = showOnboardingQuiz || showSortingQuiz;
@@ -25,7 +25,7 @@ const StyledAnchor = /*#__PURE__*/_styled(Anchor, {
25
25
  my: 24,
26
26
  padding: 0,
27
27
  width: 'calc(100% - 64px)'
28
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA0CqB","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text variant=\"p-large\" fontSize={18} pl={8}>\n              Back\n            </Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
28
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA0CqB","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text variant=\"p-large\" fontSize={18} pl={8}>\n              Back\n            </Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={displayGlobalNavRedesign ? 'transparent' : 'white'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
29
29
  const StyledStandardRedesignAnchor = /*#__PURE__*/_styled(Anchor, {
30
30
  target: "e1ch795o1",
31
31
  label: "StyledStandardRedesignAnchor"
@@ -36,7 +36,7 @@ const StyledStandardRedesignAnchor = /*#__PURE__*/_styled(Anchor, {
36
36
  py: 8,
37
37
  mt: 0,
38
38
  mb: 16
39
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AAoDqC","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text variant=\"p-large\" fontSize={18} pl={8}>\n              Back\n            </Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
39
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AAoDqC","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text variant=\"p-large\" fontSize={18} pl={8}>\n              Back\n            </Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={displayGlobalNavRedesign ? 'transparent' : 'white'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
40
40
  const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
41
41
  target: "e1ch795o0",
42
42
  label: "BackgroundWrapper"
@@ -49,7 +49,7 @@ const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
49
49
  padding: '16px',
50
50
  mx: 16
51
51
  }
52
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA+D0B","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text variant=\"p-large\" fontSize={18} pl={8}>\n              Back\n            </Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
52
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA+D0B","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text variant=\"p-large\" fontSize={18} pl={8}>\n              Back\n            </Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={displayGlobalNavRedesign ? 'transparent' : 'white'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
53
53
  const renderHeaderSection = (item, action, handleCloseMainMenu, displayGlobalNavRedesign, handleCloseSubMenu) => {
54
54
  switch (item.type) {
55
55
  case 'catalog-dropdown':
@@ -172,6 +172,7 @@ export const AppHeaderSubNavMobile = ({
172
172
  sm: 32
173
173
  } : 0,
174
174
  width: displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)',
175
+ bg: displayGlobalNavRedesign ? 'transparent' : 'white',
175
176
  children: renderHeaderSection(item, action, handleCloseMainMenu, displayGlobalNavRedesign, handleCloseSubMenu)
176
177
  })]
177
178
  })]
@@ -11,4 +11,24 @@ export interface GlobalHeaderDynamicDataContextType {
11
11
  }
12
12
  declare const GlobalHeaderDynamicDataContext: React.Context<GlobalHeaderDynamicDataContextType>;
13
13
  export declare const useGlobalHeaderDynamicDataContext: () => GlobalHeaderDynamicDataContextType;
14
- export { GlobalHeaderDynamicDataContext, GlobalHeaderItemClickContext };
14
+ export declare const DropdownPositions: Record<'free' | 'anon' | 'pro' | 'teams' | 'default', {
15
+ catalogDropdown: {
16
+ narrow: string;
17
+ wide: string;
18
+ };
19
+ resourceDropdown: {
20
+ narrow: string;
21
+ wide: string;
22
+ };
23
+ }>;
24
+ declare const HeaderDisplayContext: React.Context<{
25
+ showOnboardingQuiz?: boolean;
26
+ showSortingQuiz?: boolean;
27
+ headerType: keyof typeof DropdownPositions;
28
+ }>;
29
+ export declare const useHeaderDisplayContext: () => {
30
+ showOnboardingQuiz?: boolean;
31
+ showSortingQuiz?: boolean;
32
+ headerType: keyof typeof DropdownPositions;
33
+ };
34
+ export { GlobalHeaderDynamicDataContext, GlobalHeaderItemClickContext, HeaderDisplayContext, };
@@ -1,4 +1,4 @@
1
- import { createContext, useContext } from 'react';
1
+ import React, { createContext, useContext } from 'react';
2
2
  const GlobalHeaderItemClickContext = /*#__PURE__*/createContext({
3
3
  // eslint-disable-next-line @typescript-eslint/no-empty-function
4
4
  globalHeaderItemClick: () => {}
@@ -12,4 +12,66 @@ const GlobalHeaderDynamicDataContext = /*#__PURE__*/createContext({
12
12
  export const useGlobalHeaderDynamicDataContext = () => {
13
13
  return useContext(GlobalHeaderDynamicDataContext);
14
14
  };
15
- export { GlobalHeaderDynamicDataContext, GlobalHeaderItemClickContext };
15
+ export const DropdownPositions = {
16
+ free: {
17
+ catalogDropdown: {
18
+ narrow: '-9rem',
19
+ wide: '-14rem'
20
+ },
21
+ resourceDropdown: {
22
+ narrow: '-14.5rem',
23
+ wide: '-19.5rem'
24
+ }
25
+ },
26
+ anon: {
27
+ catalogDropdown: {
28
+ narrow: '-4rem',
29
+ wide: '-9.5rem'
30
+ },
31
+ resourceDropdown: {
32
+ narrow: '-9.5rem',
33
+ wide: '-14.5rem'
34
+ }
35
+ },
36
+ pro: {
37
+ catalogDropdown: {
38
+ narrow: '-14rem',
39
+ wide: '-14rem'
40
+ },
41
+ resourceDropdown: {
42
+ narrow: '-19.5rem',
43
+ wide: '-19.5rem'
44
+ }
45
+ },
46
+ teams: {
47
+ catalogDropdown: {
48
+ narrow: '-14rem',
49
+ wide: '-14rem'
50
+ },
51
+ resourceDropdown: {
52
+ narrow: '-19.5rem',
53
+ wide: '-19.5rem'
54
+ }
55
+ },
56
+ // won't be used, but is here to handle the case where the header type is not one of the above
57
+ // other header types are not part of the experiment
58
+ default: {
59
+ catalogDropdown: {
60
+ narrow: '-14rem',
61
+ wide: '-14rem'
62
+ },
63
+ resourceDropdown: {
64
+ narrow: '-19.5rem',
65
+ wide: '-19.5rem'
66
+ }
67
+ }
68
+ };
69
+ const HeaderDisplayContext = /*#__PURE__*/React.createContext({
70
+ showOnboardingQuiz: false,
71
+ showSortingQuiz: false,
72
+ headerType: 'default'
73
+ });
74
+ export const useHeaderDisplayContext = () => {
75
+ return useContext(HeaderDisplayContext);
76
+ };
77
+ export { GlobalHeaderDynamicDataContext, GlobalHeaderItemClickContext, HeaderDisplayContext };
@@ -2,10 +2,6 @@ import * as React from 'react';
2
2
  import { AnonHeader, EnterpriseHeader, FreeHeader, LoadingHeader, ProHeader, SimpleBootcampHeader, SimpleHeader, TeamsHeader } from './types';
3
3
  export * from './types';
4
4
  export declare const LiveLearningHubContext: React.Context<boolean>;
5
- export declare const HeaderQuizContext: React.Context<{
6
- showOnboardingQuiz?: boolean;
7
- showSortingQuiz?: boolean;
8
- }>;
9
5
  export declare const GlobalNavRedesignContext: React.Context<boolean>;
10
6
  export declare const BlpHeroExperimentContext: React.Context<boolean>;
11
7
  export type GlobalHeaderProps = AnonHeader | FreeHeader | ProHeader | EnterpriseHeader | TeamsHeader | LoadingHeader | SimpleHeader | SimpleBootcampHeader;
@@ -3,15 +3,11 @@ import { useTheme } from '@emotion/react';
3
3
  import * as React from 'react';
4
4
  import { useCallback, useMemo } from 'react';
5
5
  import { AppHeader, AppHeaderMobile, isAppHeaderItemWithHref } from '..';
6
- import { GlobalHeaderDynamicDataContext, GlobalHeaderItemClickContext } from './context';
6
+ import { DropdownPositions, GlobalHeaderDynamicDataContext, GlobalHeaderItemClickContext, HeaderDisplayContext } from './context';
7
7
  import { anonDefaultHeaderItems, anonDefaultMobileHeaderItems, anonLandingHeaderItems, anonLandingMobileHeaderItems, anonLoginHeaderItems, anonLoginMobileHeaderItems, anonSignupHeaderItems, anonSignupMobileHeaderItems, enterpriseHeaderItems, enterpriseMobileHeaderItems, freeHeaderItems, freeMobileHeaderItems, loadingHeaderItems, loadingMobileHeaderItems, proHeaderItems, proMobileHeaderItems, simpleBootcampHeaderItems, simpleBootcampMobileHeaderItems, simpleHeaderItems, simpleMobileHeaderItems, teamsHeaderItems, teamsMobileHeaderItems } from './GlobalHeaderVariants';
8
8
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
9
9
  export * from './types';
10
10
  export const LiveLearningHubContext = /*#__PURE__*/React.createContext(false);
11
- export const HeaderQuizContext = /*#__PURE__*/React.createContext({
12
- showOnboardingQuiz: false,
13
- showSortingQuiz: false
14
- });
15
11
  export const GlobalNavRedesignContext = /*#__PURE__*/React.createContext(false);
16
12
  export const BlpHeroExperimentContext = /*#__PURE__*/React.createContext(false);
17
13
 
@@ -67,10 +63,14 @@ export const GlobalHeader = props => {
67
63
  const hideNotification = props.type === 'loading' || props.type === 'enterprise' || props.type === 'simple' || props.type === 'bootcamp';
68
64
  const showOnboardingQuiz = props.type === 'anon' || (props.type === 'free' || props.type === 'pro') && !props.user.enrolledInTwoOrMoreContainers;
69
65
  const showSortingQuiz = (props.type === 'free' || props.type === 'pro') && props.user.enrolledInTwoOrMoreContainers;
70
- return /*#__PURE__*/_jsx(HeaderQuizContext.Provider, {
66
+ return /*#__PURE__*/_jsx(HeaderDisplayContext.Provider, {
71
67
  value: {
72
68
  showOnboardingQuiz,
73
- showSortingQuiz
69
+ showSortingQuiz,
70
+ headerType: useMemo(() => {
71
+ if (props.type in DropdownPositions) return props.type;
72
+ return 'default';
73
+ }, [props.type])
74
74
  },
75
75
  children: /*#__PURE__*/_jsx(GlobalNavRedesignContext.Provider, {
76
76
  value: !!props.displayGlobalNavRedesign,