@codecademy/brand 3.27.0 → 3.28.0-alpha.0f5fb538f5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.js +7 -5
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.d.ts +2 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.js +51 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/index.js +5 -4
- package/dist/AppHeader/AppHeaderElements/AppHeaderDietCard/index.js +7 -5
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileNavMenu.js +12 -3
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.js +43 -16
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/PanelLayout.d.ts +2 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/PanelLayout.js +8 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.d.ts +3 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.js +18 -12
- package/dist/AppHeaderMobile/AppHeaderSubMenuMobile/index.js +8 -6
- package/dist/GlobalHeader/context.d.ts +3 -1
- package/dist/GlobalHeader/context.js +19 -15
- package/dist/GlobalHeader/index.js +50 -47
- package/dist/GlobalHeader/types.d.ts +1 -0
- package/package.json +1 -1
|
@@ -4,18 +4,19 @@ import { Box, FlexBox, Text } from '@codecademy/gamut';
|
|
|
4
4
|
import { ArrowChevronRightIcon } from '@codecademy/gamut-icons';
|
|
5
5
|
import { motion } from 'framer-motion';
|
|
6
6
|
import React, { useCallback, useContext, useEffect, useRef } from 'react';
|
|
7
|
-
import { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';
|
|
7
|
+
import { useGlobalHeaderItemClick, useHighlightLiveLearningContext } from '../../../GlobalHeader/context';
|
|
8
8
|
import { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';
|
|
9
|
+
import { PopularBadge } from './elements';
|
|
9
10
|
import { NavIconButton } from './MobileBackButton';
|
|
10
11
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
11
12
|
const NavPanelContainer = /*#__PURE__*/_styled(Box, {
|
|
12
|
-
target: "
|
|
13
|
+
target: "ed97qwe5",
|
|
13
14
|
label: "NavPanelContainer"
|
|
14
15
|
})("border-radius:", ({
|
|
15
16
|
isFirst
|
|
16
|
-
}) => isFirst ? '0 8px 8px 8px' : '8px', ";@media (max-width: 1200px){border-radius:8px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
17
|
+
}) => isFirst ? '0 8px 8px 8px' : '8px', ";@media (max-width: 1200px){border-radius:8px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAkC2D","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
|
|
17
18
|
export const NavigationButton = /*#__PURE__*/_styled("button", {
|
|
18
|
-
target: "
|
|
19
|
+
target: "ed97qwe4",
|
|
19
20
|
label: "NavigationButton"
|
|
20
21
|
})("grid-column:1;grid-row:", ({
|
|
21
22
|
index
|
|
@@ -34,26 +35,26 @@ export const NavigationButton = /*#__PURE__*/_styled("button", {
|
|
|
34
35
|
isActive
|
|
35
36
|
}) => isActive ? theme.colors.background : theme.colors['navy-100'], ";color:", ({
|
|
36
37
|
theme
|
|
37
|
-
}) => theme.colors.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
38
|
+
}) => theme.colors.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AA6CE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
|
|
38
39
|
const OverflowText = /*#__PURE__*/_styled(Text, {
|
|
39
|
-
target: "
|
|
40
|
+
target: "ed97qwe3",
|
|
40
41
|
label: "OverflowText"
|
|
41
42
|
})(process.env.NODE_ENV === "production" ? {
|
|
42
43
|
name: "12wal98",
|
|
43
44
|
styles: "text-overflow:ellipsis;overflow:hidden;white-space:nowrap"
|
|
44
45
|
} : {
|
|
45
46
|
name: "12wal98",
|
|
46
|
-
styles: "text-overflow:ellipsis;overflow:hidden;white-space:nowrap/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
47
|
+
styles: "text-overflow:ellipsis;overflow:hidden;white-space:nowrap/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAwEiC","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */",
|
|
47
48
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
48
49
|
});
|
|
49
50
|
const StyledArrowChevronRightIcon = /*#__PURE__*/_styled(ArrowChevronRightIcon, {
|
|
50
|
-
target: "
|
|
51
|
+
target: "ed97qwe2",
|
|
51
52
|
label: "StyledArrowChevronRightIcon"
|
|
52
53
|
})("display:", ({
|
|
53
54
|
isActive
|
|
54
|
-
}) => isActive ? 'block' : 'none', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
55
|
+
}) => isActive ? 'block' : 'none', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAgFE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
|
|
55
56
|
const NavIconButtonContainer = /*#__PURE__*/_styled(Box, {
|
|
56
|
-
target: "
|
|
57
|
+
target: "ed97qwe1",
|
|
57
58
|
label: "NavIconButtonContainer"
|
|
58
59
|
})("background-color:", ({
|
|
59
60
|
theme,
|
|
@@ -62,7 +63,15 @@ const NavIconButtonContainer = /*#__PURE__*/_styled(Box, {
|
|
|
62
63
|
isActive
|
|
63
64
|
}) => isActive ? '8px 0 0 8px' : '8px', ";grid-column:1;grid-row:", ({
|
|
64
65
|
index
|
|
65
|
-
}) => index, ";padding:8px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
66
|
+
}) => index, ";padding:8px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAuFE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
|
|
67
|
+
const PopularBadgeDot = /*#__PURE__*/_styled(Box, {
|
|
68
|
+
target: "ed97qwe0",
|
|
69
|
+
label: "PopularBadgeDot"
|
|
70
|
+
})("background-color:", ({
|
|
71
|
+
theme
|
|
72
|
+
}) => theme.colors['hyper-400'], ";border-radius:8px;height:16px;width:16px;border:2px solid ", ({
|
|
73
|
+
theme
|
|
74
|
+
}) => theme.colors['gray-100'], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAiGmC","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
|
|
66
75
|
const NavSection = ({
|
|
67
76
|
isActiveTab,
|
|
68
77
|
setActiveTab,
|
|
@@ -76,6 +85,7 @@ const NavSection = ({
|
|
|
76
85
|
const {
|
|
77
86
|
globalHeaderItemClick
|
|
78
87
|
} = useGlobalHeaderItemClick();
|
|
88
|
+
const displayHighlightLiveLearning = useHighlightLiveLearningContext();
|
|
79
89
|
const {
|
|
80
90
|
setFirstItemRef
|
|
81
91
|
} = useContext(AppHeaderDropdownContext);
|
|
@@ -90,6 +100,8 @@ const NavSection = ({
|
|
|
90
100
|
globalHeaderItemClick(e, item);
|
|
91
101
|
setActiveTab(index);
|
|
92
102
|
}, [globalHeaderItemClick, item, index, setActiveTab]);
|
|
103
|
+
const highlightLiveLearning = item.id === 'live-learning' && displayHighlightLiveLearning;
|
|
104
|
+
const showPopularBadge = highlightLiveLearning && !isActiveTab;
|
|
93
105
|
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
94
106
|
children: [/*#__PURE__*/_jsx(Box, {
|
|
95
107
|
display: {
|
|
@@ -133,9 +145,20 @@ const NavSection = ({
|
|
|
133
145
|
children: /*#__PURE__*/_jsx(StyledArrowChevronRightIcon, {
|
|
134
146
|
isActive: isActiveTab
|
|
135
147
|
})
|
|
148
|
+
}), showPopularBadge && /*#__PURE__*/_jsx(Box, {
|
|
149
|
+
display: {
|
|
150
|
+
_: 'none',
|
|
151
|
+
sm: 'block'
|
|
152
|
+
},
|
|
153
|
+
children: /*#__PURE__*/_jsx(PopularBadge, {
|
|
154
|
+
variant: "custom",
|
|
155
|
+
size: "sm",
|
|
156
|
+
bg: "hyper-400",
|
|
157
|
+
children: "Popular"
|
|
158
|
+
})
|
|
136
159
|
})]
|
|
137
160
|
})
|
|
138
|
-
}), Icon && /*#__PURE__*/
|
|
161
|
+
}), Icon && /*#__PURE__*/_jsxs(NavIconButtonContainer, {
|
|
139
162
|
isActive: isActiveTab,
|
|
140
163
|
display: {
|
|
141
164
|
_: 'none',
|
|
@@ -143,17 +166,21 @@ const NavSection = ({
|
|
|
143
166
|
sm: 'none'
|
|
144
167
|
},
|
|
145
168
|
index: gridRow,
|
|
146
|
-
children: /*#__PURE__*/_jsx(NavIconButton, {
|
|
169
|
+
children: [/*#__PURE__*/_jsx(NavIconButton, {
|
|
147
170
|
onClick: onSelect,
|
|
148
171
|
icon: Icon,
|
|
149
|
-
tip: text,
|
|
172
|
+
tip: highlightLiveLearning ? 'Live learning (popular)' : text,
|
|
150
173
|
tipProps: {
|
|
151
174
|
alignment: 'right-center',
|
|
152
175
|
narrow: false,
|
|
153
176
|
placement: 'floating'
|
|
154
177
|
},
|
|
155
|
-
"aria-label": text
|
|
156
|
-
})
|
|
178
|
+
"aria-label": highlightLiveLearning ? 'Live learning (popular)' : text
|
|
179
|
+
}), showPopularBadge && /*#__PURE__*/_jsx(PopularBadgeDot, {
|
|
180
|
+
position: "absolute",
|
|
181
|
+
left: "42px",
|
|
182
|
+
"aria-hidden": true
|
|
183
|
+
})]
|
|
157
184
|
}), /*#__PURE__*/_jsx(NavPanelContainer, {
|
|
158
185
|
isFirst: index === 0,
|
|
159
186
|
display: isActiveTab ? 'block' : 'none',
|
|
@@ -4,6 +4,7 @@ type PanelLayoutProps = PropsWithChildren & {
|
|
|
4
4
|
heading: string;
|
|
5
5
|
description: ReactNode;
|
|
6
6
|
linkItem?: AppHeaderLinkItem;
|
|
7
|
+
showPopularBadge?: boolean;
|
|
7
8
|
};
|
|
8
|
-
export declare const PanelLayout: ({ heading, description, linkItem, children, }: PanelLayoutProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare const PanelLayout: ({ heading, description, linkItem, showPopularBadge, children, }: PanelLayoutProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
10
|
export {};
|
|
@@ -3,11 +3,13 @@ import { ArrowLeftIcon, MiniArrowRightIcon } from '@codecademy/gamut-icons';
|
|
|
3
3
|
import { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';
|
|
4
4
|
import { useAppHeaderDropdownContext } from '../AppHeaderDropdownProvider';
|
|
5
5
|
import { useAppHeaderSectionContext } from './AppHeaderSectionContext';
|
|
6
|
+
import { PopularBadge } from './elements';
|
|
6
7
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
7
8
|
export const PanelLayout = ({
|
|
8
9
|
heading,
|
|
9
10
|
description,
|
|
10
11
|
linkItem,
|
|
12
|
+
showPopularBadge,
|
|
11
13
|
children
|
|
12
14
|
}) => {
|
|
13
15
|
const {
|
|
@@ -55,6 +57,12 @@ export const PanelLayout = ({
|
|
|
55
57
|
as: "h2",
|
|
56
58
|
variant: "title-sm",
|
|
57
59
|
children: heading
|
|
60
|
+
}), showPopularBadge && /*#__PURE__*/_jsx(PopularBadge, {
|
|
61
|
+
variant: "custom",
|
|
62
|
+
size: "base",
|
|
63
|
+
bg: "hyper-400",
|
|
64
|
+
ml: 16,
|
|
65
|
+
children: "Popular"
|
|
58
66
|
})]
|
|
59
67
|
}), /*#__PURE__*/_jsx(Text, {
|
|
60
68
|
mb: 16,
|
|
@@ -24,3 +24,6 @@ export declare const SmallMenuButton: import("@emotion/styled").StyledComponent<
|
|
|
24
24
|
} & {
|
|
25
25
|
index: number;
|
|
26
26
|
}, import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {}>;
|
|
27
|
+
export declare const PopularBadge: import("@emotion/styled").StyledComponent<import("@codecademy/gamut").BadgeProps & {
|
|
28
|
+
theme?: import("@emotion/react").Theme;
|
|
29
|
+
}, {}, {}>;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
2
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
3
|
-
import { Box, GridBox } from '@codecademy/gamut';
|
|
3
|
+
import { Badge, Box, GridBox } from '@codecademy/gamut';
|
|
4
4
|
export const StyledSection = /*#__PURE__*/_styled(Box, {
|
|
5
|
-
target: "
|
|
5
|
+
target: "e2xtrjc4",
|
|
6
6
|
label: "StyledSection"
|
|
7
7
|
})("width:100%;max-width:100%;border:1px solid ", ({
|
|
8
8
|
theme
|
|
@@ -11,31 +11,31 @@ export const StyledSection = /*#__PURE__*/_styled(Box, {
|
|
|
11
11
|
theme
|
|
12
12
|
}) => activePanelSelected ? theme.colors['gray-100'] : theme.colors.background, ";@media (min-width: 480px){background-color:", ({
|
|
13
13
|
theme
|
|
14
|
-
}) => theme.colors['gray-100'], ";}@media (min-width: 1200px){width:calc(100dvw - 11rem);max-width:calc(1440px - 11rem);max-height:85vh;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14
|
+
}) => theme.colors['gray-100'], ";}@media (min-width: 1200px){width:calc(100dvw - 11rem);max-width:calc(1440px - 11rem);max-height:85vh;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbi9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRzBFIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbi9lbGVtZW50cy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYWRnZSwgQm94LCBHcmlkQm94IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkU2VjdGlvbiA9IHN0eWxlZChCb3gpPHsgYWN0aXZlUGFuZWxTZWxlY3RlZDogYm9vbGVhbiB9PmBcbiAgd2lkdGg6IDEwMCU7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnNbJ2JvcmRlci10ZXJ0aWFyeSddfTtcbiAgYm9yZGVyLXJhZGl1czogMTZweDtcbiAgb3ZlcmZsb3cteTogYXV0bztcbiAgb3ZlcmZsb3cteDogaGlkZGVuO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IGFjdGl2ZVBhbmVsU2VsZWN0ZWQsIHRoZW1lIH0pID0+XG4gICAgYWN0aXZlUGFuZWxTZWxlY3RlZCA/IHRoZW1lLmNvbG9yc1snZ3JheS0xMDAnXSA6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kfTtcblxuICBAbWVkaWEgKG1pbi13aWR0aDogNDgwcHgpIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9yc1snZ3JheS0xMDAnXX07XG4gIH1cblxuICAvLyBhdCB0aGlzIGJyZWFrcG9pbnQgdGhlIG1lbnUgYmVjb21lcyBhIGRyb3Bkb3duXG4gIEBtZWRpYSAobWluLXdpZHRoOiAxMjAwcHgpIHtcbiAgICB3aWR0aDogY2FsYygxMDBkdncgLSAxMXJlbSk7XG4gICAgbWF4LXdpZHRoOiBjYWxjKDE0NDBweCAtIDExcmVtKTtcbiAgICBtYXgtaGVpZ2h0OiA4NXZoO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkR3JpZEJveCA9IHN0eWxlZChHcmlkQm94KWBcbiAgcGFkZGluZzogOHB4O1xuICByb3ctZ2FwOiA4cHg7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogMjY1cHggMzJweCAxZnI7XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6IDc2N3B4KSB7XG4gICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiA2NHB4IDFmciAxZnI7XG4gIH1cblxuICBAbWVkaWEgKG1heC13aWR0aDogNDc5cHgpIHtcbiAgICBkaXNwbGF5OiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JhZGllbnRCYWNrZ3JvdW5kID0gc3R5bGVkKEJveClgXG4gIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAxODBkZWcsXG4gICAgcmdiYSgwLCAwLCAwLCAwKSA3LjY1JSxcbiAgICByZ2JhKDAsIDAsIDAsIDAuMTUpIDEwMCVcbiAgKTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTbWFsbE1lbnVCdXR0b24gPSBzdHlsZWQuYnV0dG9uPHsgaW5kZXg6IG51bWJlciB9PmBcbiAgZ3JpZC1jb2x1bW46IDE7XG4gIGdyaWQtcm93OiAkeyh7IGluZGV4IH0pID0+IGluZGV4ICsgMX07XG4gIHBhZGRpbmc6IDE2cHg7XG4gIGJvcmRlcjogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogOHB4O1xuICBiYWNrZ3JvdW5kOiBub25lO1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy50ZXh0fTtcbiAgd2lkdGg6IDEwMCU7XG4gIHRleHQtYWxpZ246IGxlZnQ7XG4gIGhlaWdodDogNjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICY6aG92ZXIsXG4gICY6Zm9jdXMge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzWyduYXZ5LTEwMCddfTtcbiAgICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMucHJpbWFyeX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQb3B1bGFyQmFkZ2UgPSBzdHlsZWQoQmFkZ2UpYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMud2hpdGV9O1xuYDtcbiJdfQ== */"));
|
|
15
15
|
export const StyledGridBox = /*#__PURE__*/_styled(GridBox, {
|
|
16
|
-
target: "
|
|
16
|
+
target: "e2xtrjc3",
|
|
17
17
|
label: "StyledGridBox"
|
|
18
18
|
})(process.env.NODE_ENV === "production" ? {
|
|
19
|
-
name: "
|
|
20
|
-
styles: "padding:8px;row-gap:8px;grid-template-columns:265px 32px 1fr;@media (max-width:
|
|
19
|
+
name: "y6u6vo",
|
|
20
|
+
styles: "padding:8px;row-gap:8px;grid-template-columns:265px 32px 1fr;@media (max-width: 767px){grid-template-columns:64px 1fr 1fr;}@media (max-width: 479px){display:none;}"
|
|
21
21
|
} : {
|
|
22
|
-
name: "
|
|
23
|
-
styles: "padding:8px;row-gap:8px;grid-template-columns:265px 32px 1fr;@media (max-width:
|
|
22
|
+
name: "y6u6vo",
|
|
23
|
+
styles: "padding:8px;row-gap:8px;grid-template-columns:265px 32px 1fr;@media (max-width: 767px){grid-template-columns:64px 1fr 1fr;}@media (max-width: 479px){display:none;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbi9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUI0QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlclNlY3Rpb24vZWxlbWVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgR3JpZEJveCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNlY3Rpb24gPSBzdHlsZWQoQm94KTx7IGFjdGl2ZVBhbmVsU2VsZWN0ZWQ6IGJvb2xlYW4gfT5gXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzWydib3JkZXItdGVydGlhcnknXX07XG4gIGJvcmRlci1yYWRpdXM6IDE2cHg7XG4gIG92ZXJmbG93LXk6IGF1dG87XG4gIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyBhY3RpdmVQYW5lbFNlbGVjdGVkLCB0aGVtZSB9KSA9PlxuICAgIGFjdGl2ZVBhbmVsU2VsZWN0ZWQgPyB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ10gOiB0aGVtZS5jb2xvcnMuYmFja2dyb3VuZH07XG5cbiAgQG1lZGlhIChtaW4td2lkdGg6IDQ4MHB4KSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ119O1xuICB9XG5cbiAgLy8gYXQgdGhpcyBicmVha3BvaW50IHRoZSBtZW51IGJlY29tZXMgYSBkcm9wZG93blxuICBAbWVkaWEgKG1pbi13aWR0aDogMTIwMHB4KSB7XG4gICAgd2lkdGg6IGNhbGMoMTAwZHZ3IC0gMTFyZW0pO1xuICAgIG1heC13aWR0aDogY2FsYygxNDQwcHggLSAxMXJlbSk7XG4gICAgbWF4LWhlaWdodDogODV2aDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEdyaWRCb3ggPSBzdHlsZWQoR3JpZEJveClgXG4gIHBhZGRpbmc6IDhweDtcbiAgcm93LWdhcDogOHB4O1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDI2NXB4IDMycHggMWZyO1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiA3NjdweCkge1xuICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogNjRweCAxZnIgMWZyO1xuICB9XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6IDQ3OXB4KSB7XG4gICAgZGlzcGxheTogbm9uZTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEdyYWRpZW50QmFja2dyb3VuZCA9IHN0eWxlZChCb3gpYFxuICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgMTgwZGVnLFxuICAgIHJnYmEoMCwgMCwgMCwgMCkgNy42NSUsXG4gICAgcmdiYSgwLCAwLCAwLCAwLjE1KSAxMDAlXG4gICk7XG5gO1xuXG5leHBvcnQgY29uc3QgU21hbGxNZW51QnV0dG9uID0gc3R5bGVkLmJ1dHRvbjx7IGluZGV4OiBudW1iZXIgfT5gXG4gIGdyaWQtY29sdW1uOiAxO1xuICBncmlkLXJvdzogJHsoeyBpbmRleCB9KSA9PiBpbmRleCArIDF9O1xuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXI6IG5vbmU7XG4gIGJvcmRlci1yYWRpdXM6IDhweDtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMudGV4dH07XG4gIHdpZHRoOiAxMDAlO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBoZWlnaHQ6IDYwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAmOmhvdmVyLFxuICAmOmZvY3VzIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9yc1snbmF2eS0xMDAnXX07XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUG9wdWxhckJhZGdlID0gc3R5bGVkKEJhZGdlKWBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLndoaXRlfTtcbmA7XG4iXX0= */",
|
|
24
24
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
25
25
|
});
|
|
26
26
|
export const GradientBackground = /*#__PURE__*/_styled(Box, {
|
|
27
|
-
target: "
|
|
27
|
+
target: "e2xtrjc2",
|
|
28
28
|
label: "GradientBackground"
|
|
29
29
|
})(process.env.NODE_ENV === "production" ? {
|
|
30
30
|
name: "1n848ez",
|
|
31
31
|
styles: "background:linear-gradient(\n 180deg,\n rgba(0, 0, 0, 0) 7.65%,\n rgba(0, 0, 0, 0.15) 100%\n )"
|
|
32
32
|
} : {
|
|
33
33
|
name: "1n848ez",
|
|
34
|
-
styles: "background:linear-gradient(\n 180deg,\n rgba(0, 0, 0, 0) 7.65%,\n rgba(0, 0, 0, 0.15) 100%\n )/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
34
|
+
styles: "background:linear-gradient(\n 180deg,\n rgba(0, 0, 0, 0) 7.65%,\n rgba(0, 0, 0, 0.15) 100%\n )/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbi9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUM2QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlclNlY3Rpb24vZWxlbWVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgR3JpZEJveCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNlY3Rpb24gPSBzdHlsZWQoQm94KTx7IGFjdGl2ZVBhbmVsU2VsZWN0ZWQ6IGJvb2xlYW4gfT5gXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzWydib3JkZXItdGVydGlhcnknXX07XG4gIGJvcmRlci1yYWRpdXM6IDE2cHg7XG4gIG92ZXJmbG93LXk6IGF1dG87XG4gIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyBhY3RpdmVQYW5lbFNlbGVjdGVkLCB0aGVtZSB9KSA9PlxuICAgIGFjdGl2ZVBhbmVsU2VsZWN0ZWQgPyB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ10gOiB0aGVtZS5jb2xvcnMuYmFja2dyb3VuZH07XG5cbiAgQG1lZGlhIChtaW4td2lkdGg6IDQ4MHB4KSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ119O1xuICB9XG5cbiAgLy8gYXQgdGhpcyBicmVha3BvaW50IHRoZSBtZW51IGJlY29tZXMgYSBkcm9wZG93blxuICBAbWVkaWEgKG1pbi13aWR0aDogMTIwMHB4KSB7XG4gICAgd2lkdGg6IGNhbGMoMTAwZHZ3IC0gMTFyZW0pO1xuICAgIG1heC13aWR0aDogY2FsYygxNDQwcHggLSAxMXJlbSk7XG4gICAgbWF4LWhlaWdodDogODV2aDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEdyaWRCb3ggPSBzdHlsZWQoR3JpZEJveClgXG4gIHBhZGRpbmc6IDhweDtcbiAgcm93LWdhcDogOHB4O1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDI2NXB4IDMycHggMWZyO1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiA3NjdweCkge1xuICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogNjRweCAxZnIgMWZyO1xuICB9XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6IDQ3OXB4KSB7XG4gICAgZGlzcGxheTogbm9uZTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEdyYWRpZW50QmFja2dyb3VuZCA9IHN0eWxlZChCb3gpYFxuICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgMTgwZGVnLFxuICAgIHJnYmEoMCwgMCwgMCwgMCkgNy42NSUsXG4gICAgcmdiYSgwLCAwLCAwLCAwLjE1KSAxMDAlXG4gICk7XG5gO1xuXG5leHBvcnQgY29uc3QgU21hbGxNZW51QnV0dG9uID0gc3R5bGVkLmJ1dHRvbjx7IGluZGV4OiBudW1iZXIgfT5gXG4gIGdyaWQtY29sdW1uOiAxO1xuICBncmlkLXJvdzogJHsoeyBpbmRleCB9KSA9PiBpbmRleCArIDF9O1xuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXI6IG5vbmU7XG4gIGJvcmRlci1yYWRpdXM6IDhweDtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMudGV4dH07XG4gIHdpZHRoOiAxMDAlO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBoZWlnaHQ6IDYwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAmOmhvdmVyLFxuICAmOmZvY3VzIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9yc1snbmF2eS0xMDAnXX07XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUG9wdWxhckJhZGdlID0gc3R5bGVkKEJhZGdlKWBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLndoaXRlfTtcbmA7XG4iXX0= */",
|
|
35
35
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
36
36
|
});
|
|
37
37
|
export const SmallMenuButton = /*#__PURE__*/_styled("button", {
|
|
38
|
-
target: "
|
|
38
|
+
target: "e2xtrjc1",
|
|
39
39
|
label: "SmallMenuButton"
|
|
40
40
|
})("grid-column:1;grid-row:", ({
|
|
41
41
|
index
|
|
@@ -45,4 +45,10 @@ export const SmallMenuButton = /*#__PURE__*/_styled("button", {
|
|
|
45
45
|
theme
|
|
46
46
|
}) => theme.colors['navy-100'], ";color:", ({
|
|
47
47
|
theme
|
|
48
|
-
}) => theme.colors.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
48
|
+
}) => theme.colors.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbi9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0MrRCIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlclNlY3Rpb24vZWxlbWVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgR3JpZEJveCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNlY3Rpb24gPSBzdHlsZWQoQm94KTx7IGFjdGl2ZVBhbmVsU2VsZWN0ZWQ6IGJvb2xlYW4gfT5gXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzWydib3JkZXItdGVydGlhcnknXX07XG4gIGJvcmRlci1yYWRpdXM6IDE2cHg7XG4gIG92ZXJmbG93LXk6IGF1dG87XG4gIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyBhY3RpdmVQYW5lbFNlbGVjdGVkLCB0aGVtZSB9KSA9PlxuICAgIGFjdGl2ZVBhbmVsU2VsZWN0ZWQgPyB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ10gOiB0aGVtZS5jb2xvcnMuYmFja2dyb3VuZH07XG5cbiAgQG1lZGlhIChtaW4td2lkdGg6IDQ4MHB4KSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ119O1xuICB9XG5cbiAgLy8gYXQgdGhpcyBicmVha3BvaW50IHRoZSBtZW51IGJlY29tZXMgYSBkcm9wZG93blxuICBAbWVkaWEgKG1pbi13aWR0aDogMTIwMHB4KSB7XG4gICAgd2lkdGg6IGNhbGMoMTAwZHZ3IC0gMTFyZW0pO1xuICAgIG1heC13aWR0aDogY2FsYygxNDQwcHggLSAxMXJlbSk7XG4gICAgbWF4LWhlaWdodDogODV2aDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEdyaWRCb3ggPSBzdHlsZWQoR3JpZEJveClgXG4gIHBhZGRpbmc6IDhweDtcbiAgcm93LWdhcDogOHB4O1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDI2NXB4IDMycHggMWZyO1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiA3NjdweCkge1xuICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogNjRweCAxZnIgMWZyO1xuICB9XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6IDQ3OXB4KSB7XG4gICAgZGlzcGxheTogbm9uZTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEdyYWRpZW50QmFja2dyb3VuZCA9IHN0eWxlZChCb3gpYFxuICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgMTgwZGVnLFxuICAgIHJnYmEoMCwgMCwgMCwgMCkgNy42NSUsXG4gICAgcmdiYSgwLCAwLCAwLCAwLjE1KSAxMDAlXG4gICk7XG5gO1xuXG5leHBvcnQgY29uc3QgU21hbGxNZW51QnV0dG9uID0gc3R5bGVkLmJ1dHRvbjx7IGluZGV4OiBudW1iZXIgfT5gXG4gIGdyaWQtY29sdW1uOiAxO1xuICBncmlkLXJvdzogJHsoeyBpbmRleCB9KSA9PiBpbmRleCArIDF9O1xuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXI6IG5vbmU7XG4gIGJvcmRlci1yYWRpdXM6IDhweDtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMudGV4dH07XG4gIHdpZHRoOiAxMDAlO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBoZWlnaHQ6IDYwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAmOmhvdmVyLFxuICAmOmZvY3VzIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9yc1snbmF2eS0xMDAnXX07XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUG9wdWxhckJhZGdlID0gc3R5bGVkKEJhZGdlKWBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLndoaXRlfTtcbmA7XG4iXX0= */"));
|
|
49
|
+
export const PopularBadge = /*#__PURE__*/_styled(Badge, {
|
|
50
|
+
target: "e2xtrjc0",
|
|
51
|
+
label: "PopularBadge"
|
|
52
|
+
})("color:", ({
|
|
53
|
+
theme
|
|
54
|
+
}) => theme.colors.white, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbi9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0V5QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlclNlY3Rpb24vZWxlbWVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgR3JpZEJveCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFNlY3Rpb24gPSBzdHlsZWQoQm94KTx7IGFjdGl2ZVBhbmVsU2VsZWN0ZWQ6IGJvb2xlYW4gfT5gXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzWydib3JkZXItdGVydGlhcnknXX07XG4gIGJvcmRlci1yYWRpdXM6IDE2cHg7XG4gIG92ZXJmbG93LXk6IGF1dG87XG4gIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyBhY3RpdmVQYW5lbFNlbGVjdGVkLCB0aGVtZSB9KSA9PlxuICAgIGFjdGl2ZVBhbmVsU2VsZWN0ZWQgPyB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ10gOiB0aGVtZS5jb2xvcnMuYmFja2dyb3VuZH07XG5cbiAgQG1lZGlhIChtaW4td2lkdGg6IDQ4MHB4KSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnNbJ2dyYXktMTAwJ119O1xuICB9XG5cbiAgLy8gYXQgdGhpcyBicmVha3BvaW50IHRoZSBtZW51IGJlY29tZXMgYSBkcm9wZG93blxuICBAbWVkaWEgKG1pbi13aWR0aDogMTIwMHB4KSB7XG4gICAgd2lkdGg6IGNhbGMoMTAwZHZ3IC0gMTFyZW0pO1xuICAgIG1heC13aWR0aDogY2FsYygxNDQwcHggLSAxMXJlbSk7XG4gICAgbWF4LWhlaWdodDogODV2aDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEdyaWRCb3ggPSBzdHlsZWQoR3JpZEJveClgXG4gIHBhZGRpbmc6IDhweDtcbiAgcm93LWdhcDogOHB4O1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDI2NXB4IDMycHggMWZyO1xuXG4gIEBtZWRpYSAobWF4LXdpZHRoOiA3NjdweCkge1xuICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogNjRweCAxZnIgMWZyO1xuICB9XG5cbiAgQG1lZGlhIChtYXgtd2lkdGg6IDQ3OXB4KSB7XG4gICAgZGlzcGxheTogbm9uZTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEdyYWRpZW50QmFja2dyb3VuZCA9IHN0eWxlZChCb3gpYFxuICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgMTgwZGVnLFxuICAgIHJnYmEoMCwgMCwgMCwgMCkgNy42NSUsXG4gICAgcmdiYSgwLCAwLCAwLCAwLjE1KSAxMDAlXG4gICk7XG5gO1xuXG5leHBvcnQgY29uc3QgU21hbGxNZW51QnV0dG9uID0gc3R5bGVkLmJ1dHRvbjx7IGluZGV4OiBudW1iZXIgfT5gXG4gIGdyaWQtY29sdW1uOiAxO1xuICBncmlkLXJvdzogJHsoeyBpbmRleCB9KSA9PiBpbmRleCArIDF9O1xuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXI6IG5vbmU7XG4gIGJvcmRlci1yYWRpdXM6IDhweDtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMudGV4dH07XG4gIHdpZHRoOiAxMDAlO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBoZWlnaHQ6IDYwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAmOmhvdmVyLFxuICAmOmZvY3VzIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9yc1snbmF2eS0xMDAnXX07XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgUG9wdWxhckJhZGdlID0gc3R5bGVkKEJhZGdlKWBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLndoaXRlfTtcbmA7XG4iXX0= */"));
|