@codecademy/brand 3.19.0-alpha.c35a1cb4bd.0 → 3.19.0-alpha.c8b1055646.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/MarketingBanner.d.ts +1 -3
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner.js +7 -4
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.d.ts +0 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.js +3 -4
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.d.ts +2 -9
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.js +2 -48
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/index.js +8 -20
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/tabConfig.d.ts +2 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/tabConfig.js +48 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdown/index.js +9 -14
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/AppHeaderDropdownLink.js +3 -2
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/AppHeaderMenuItem.js +5 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/StyledAppHeaderLink.js +5 -2
- package/dist/AppHeader/AppHeaderElements/AppHeaderLinkSections/index.js +3 -2
- package/dist/AppHeader/AppHeaderElements/AppHeaderNavButton/AppHeaderDropdownNavButton.js +5 -5
- package/dist/AppHeader/AppHeaderElements/AppHeaderNavButton/AppHeaderMenuNavButton.js +9 -7
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/NavPanels.js +12 -6
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts.d.ts +1 -8
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts.js +1 -39
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/index.js +7 -22
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/tabConfig.d.ts +2 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/tabConfig.js +39 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/AppHeaderSection.test.js +215 -30
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileBackButton.js +4 -5
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileNavMenu.d.ts +2 -5
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileNavMenu.js +7 -5
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/consts.d.ts +2 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/consts.js +37 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.d.ts +37 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.js +86 -12
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.d.ts +9 -6
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.js +123 -41
- package/dist/AppHeader/shared/elements.d.ts +15 -3
- package/dist/AppHeader/shared/elements.js +138 -27
- package/dist/AppHeaderMobile/AppHeaderSubMenuMobile/index.js +9 -11
- package/dist/LearningOutcomeTile/index.js +1 -2
- package/package.json +2 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.d.ts +0 -21
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.js +0 -162
|
@@ -3,10 +3,11 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
|
|
|
3
3
|
import { Anchor, FlexBox, LayoutGrid, Text } from '@codecademy/gamut';
|
|
4
4
|
import { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';
|
|
5
5
|
import { css, pxRem, states, useCurrentMode } from '@codecademy/gamut-styles';
|
|
6
|
-
import { AnimatePresence, motion } from 'framer-motion';
|
|
6
|
+
import { AnimatePresence, motion, useReducedMotion } from 'framer-motion';
|
|
7
7
|
import * as React from 'react';
|
|
8
8
|
import { AppBar } from '../../AppBar';
|
|
9
|
-
import {
|
|
9
|
+
import { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';
|
|
10
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
10
11
|
export const appHeaderMobileBreakpoint = 'lg';
|
|
11
12
|
const animatedPopoverVariants = {
|
|
12
13
|
enter: {
|
|
@@ -22,7 +23,6 @@ const animatedPopoverVariants = {
|
|
|
22
23
|
}
|
|
23
24
|
}
|
|
24
25
|
};
|
|
25
|
-
const borderColor = 'border-primary';
|
|
26
26
|
export const useMegaMenuHeaderResponsiveStyles = () => {
|
|
27
27
|
const mode = useCurrentMode();
|
|
28
28
|
const bg = mode === 'dark' ? 'white' : 'navy-800';
|
|
@@ -48,7 +48,7 @@ export const AnimatedHeaderZone = ({
|
|
|
48
48
|
}) : null;
|
|
49
49
|
};
|
|
50
50
|
export const DropdownAnchor = /*#__PURE__*/_styled(Anchor, {
|
|
51
|
-
target: "
|
|
51
|
+
target: "e1xddtpe9",
|
|
52
52
|
label: "DropdownAnchor"
|
|
53
53
|
})(css({
|
|
54
54
|
alignItems: `center`,
|
|
@@ -59,22 +59,22 @@ export const DropdownAnchor = /*#__PURE__*/_styled(Anchor, {
|
|
|
59
59
|
'&:focus::before': {
|
|
60
60
|
opacity: 1
|
|
61
61
|
}
|
|
62
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
62
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAsE8B","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
63
63
|
const dropdownStates = states({
|
|
64
64
|
open: {
|
|
65
65
|
transform: `rotate(-180deg)`
|
|
66
66
|
}
|
|
67
67
|
});
|
|
68
68
|
export const DropdownIcon = /*#__PURE__*/_styled(ArrowChevronDownFilledIcon, {
|
|
69
|
-
target: "
|
|
69
|
+
target: "e1xddtpe8",
|
|
70
70
|
label: "DropdownIcon"
|
|
71
71
|
})(css({
|
|
72
72
|
marginLeft: pxRem(5),
|
|
73
73
|
transition: `transform 0.35s ease-out`,
|
|
74
74
|
transformOrigin: `center ${pxRem(5)}`
|
|
75
|
-
}), dropdownStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
75
|
+
}), dropdownStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AA0F4B","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
76
76
|
export const StyledText = /*#__PURE__*/_styled(Text, {
|
|
77
|
-
target: "
|
|
77
|
+
target: "e1xddtpe7",
|
|
78
78
|
label: "StyledText"
|
|
79
79
|
})(css({
|
|
80
80
|
'&::after': {
|
|
@@ -86,26 +86,137 @@ export const StyledText = /*#__PURE__*/_styled(Text, {
|
|
|
86
86
|
overflow: `hidden`,
|
|
87
87
|
visibility: `hidden`
|
|
88
88
|
}
|
|
89
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
90
|
-
const
|
|
91
|
-
|
|
92
|
-
|
|
89
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAqG0B","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
90
|
+
const getDropdownAnimations = ({
|
|
91
|
+
prefersReducedMotion,
|
|
92
|
+
displayGlobalNavRedesign
|
|
93
|
+
}) => {
|
|
94
|
+
const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';
|
|
95
|
+
const dropdownAnimations = {
|
|
96
|
+
animate: {
|
|
97
|
+
transform: 'translateY(0)',
|
|
98
|
+
opacity: 1
|
|
99
|
+
},
|
|
100
|
+
exit: {
|
|
101
|
+
opacity: 0,
|
|
102
|
+
transform
|
|
103
|
+
},
|
|
104
|
+
initial: {
|
|
105
|
+
opacity: 0,
|
|
106
|
+
transform
|
|
107
|
+
},
|
|
108
|
+
transition: {
|
|
109
|
+
duration: 0.15,
|
|
110
|
+
ease: 'easeOut'
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
const legacyDropdownAnimations = {
|
|
114
|
+
initial: {
|
|
115
|
+
borderWidth: 0,
|
|
116
|
+
height: 0
|
|
117
|
+
},
|
|
118
|
+
exit: {
|
|
119
|
+
borderWidth: 0,
|
|
120
|
+
height: 0
|
|
121
|
+
},
|
|
122
|
+
animate: {
|
|
123
|
+
borderWidth: 1,
|
|
124
|
+
height: 'fit-content'
|
|
125
|
+
},
|
|
126
|
+
transition: {
|
|
127
|
+
duration: 0.175
|
|
128
|
+
}
|
|
129
|
+
};
|
|
130
|
+
return displayGlobalNavRedesign ? dropdownAnimations : legacyDropdownAnimations;
|
|
93
131
|
};
|
|
94
|
-
|
|
132
|
+
const MegaMenuDropdown = /*#__PURE__*/_styled(motion.create('div'), {
|
|
133
|
+
shouldForwardProp: prop => prop !== 'displayGlobalNavRedesign',
|
|
134
|
+
target: "e1xddtpe6",
|
|
135
|
+
label: "MegaMenuDropdown"
|
|
136
|
+
})(({
|
|
137
|
+
displayGlobalNavRedesign
|
|
138
|
+
}) => css({
|
|
139
|
+
bg: `background`,
|
|
140
|
+
overflow: `hidden`,
|
|
141
|
+
position: `absolute`,
|
|
142
|
+
...(!displayGlobalNavRedesign ? {
|
|
143
|
+
borderColor: 'border-primary',
|
|
144
|
+
borderStyle: 'solid'
|
|
145
|
+
} : {})
|
|
146
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAqJyB","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
147
|
+
const MegaMenuBackdrop = /*#__PURE__*/_styled(motion.create('div'), {
|
|
95
148
|
target: "e1xddtpe5",
|
|
96
|
-
label: "
|
|
149
|
+
label: "MegaMenuBackdrop"
|
|
97
150
|
})(css({
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
151
|
+
position: 'relative',
|
|
152
|
+
zIndex: -1
|
|
153
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAuKyB","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
154
|
+
export const AnimatedMegaMenuDropdown = /*#__PURE__*/React.forwardRef(({
|
|
155
|
+
isOpen,
|
|
156
|
+
displayGlobalNavRedesign = false,
|
|
157
|
+
...props
|
|
158
|
+
}, ref) => {
|
|
159
|
+
const prefersReducedMotion = useReducedMotion();
|
|
160
|
+
return /*#__PURE__*/_jsx(AnimatePresence, {
|
|
161
|
+
children: isOpen && /*#__PURE__*/_jsxs(_Fragment, {
|
|
162
|
+
children: [/*#__PURE__*/_jsx(MegaMenuBackdrop, {
|
|
163
|
+
...(displayGlobalNavRedesign ? {
|
|
164
|
+
initial: {
|
|
165
|
+
opacity: 0
|
|
166
|
+
},
|
|
167
|
+
animate: {
|
|
168
|
+
opacity: 1
|
|
169
|
+
},
|
|
170
|
+
exit: {
|
|
171
|
+
opacity: 0
|
|
172
|
+
},
|
|
173
|
+
transition: {
|
|
174
|
+
duration: 0.15,
|
|
175
|
+
ease: 'easeOut'
|
|
176
|
+
}
|
|
177
|
+
} : {}),
|
|
178
|
+
children: /*#__PURE__*/_jsx(GradientBackground, {
|
|
179
|
+
position: "fixed",
|
|
180
|
+
top: "0",
|
|
181
|
+
left: "0",
|
|
182
|
+
right: "0",
|
|
183
|
+
bottom: "0"
|
|
184
|
+
}, "dropdown-backdrop")
|
|
185
|
+
}), /*#__PURE__*/_jsx(MegaMenuDropdown, {
|
|
186
|
+
...getDropdownAnimations({
|
|
187
|
+
prefersReducedMotion,
|
|
188
|
+
displayGlobalNavRedesign
|
|
189
|
+
}),
|
|
190
|
+
displayGlobalNavRedesign: displayGlobalNavRedesign,
|
|
191
|
+
ref: ref,
|
|
192
|
+
...props
|
|
193
|
+
}, "dropdown-content")]
|
|
194
|
+
})
|
|
195
|
+
});
|
|
196
|
+
});
|
|
197
|
+
const SimpleDropdown = /*#__PURE__*/_styled(motion.create('div'), {
|
|
104
198
|
target: "e1xddtpe4",
|
|
105
|
-
label: "
|
|
199
|
+
label: "SimpleDropdown"
|
|
106
200
|
})(css({
|
|
107
|
-
|
|
108
|
-
|
|
201
|
+
overflow: `hidden`,
|
|
202
|
+
position: `absolute`
|
|
203
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAoOuB","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
204
|
+
export const AnimatedSimpleDropdown = ({
|
|
205
|
+
isOpen,
|
|
206
|
+
displayGlobalNavRedesign = false,
|
|
207
|
+
...props
|
|
208
|
+
}) => {
|
|
209
|
+
const prefersReducedMotion = useReducedMotion();
|
|
210
|
+
return /*#__PURE__*/_jsx(AnimatePresence, {
|
|
211
|
+
children: isOpen && /*#__PURE__*/_jsx(SimpleDropdown, {
|
|
212
|
+
...getDropdownAnimations({
|
|
213
|
+
prefersReducedMotion,
|
|
214
|
+
displayGlobalNavRedesign
|
|
215
|
+
}),
|
|
216
|
+
...props
|
|
217
|
+
})
|
|
218
|
+
});
|
|
219
|
+
};
|
|
109
220
|
export const LayoutGridAntiAliased = /*#__PURE__*/_styled(LayoutGrid, {
|
|
110
221
|
target: "e1xddtpe3",
|
|
111
222
|
label: "LayoutGridAntiAliased"
|
|
@@ -114,7 +225,7 @@ export const LayoutGridAntiAliased = /*#__PURE__*/_styled(LayoutGrid, {
|
|
|
114
225
|
styles: "-webkit-font-smoothing:antialiased"
|
|
115
226
|
} : {
|
|
116
227
|
name: "1y5tre4",
|
|
117
|
-
styles: "-webkit-font-smoothing:antialiased/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
228
|
+
styles: "-webkit-font-smoothing:antialiased/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAoQuD","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */",
|
|
118
229
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
119
230
|
});
|
|
120
231
|
|
|
@@ -127,13 +238,13 @@ export const DescriptionSectionContainer = /*#__PURE__*/_styled(FlexBox, {
|
|
|
127
238
|
color: 'text',
|
|
128
239
|
outline: '1px solid currentColor !important'
|
|
129
240
|
}
|
|
130
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
241
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAyQ2C","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
131
242
|
export const StyledAppBar = /*#__PURE__*/_styled(AppBar, {
|
|
132
243
|
target: "e1xddtpe1",
|
|
133
244
|
label: "StyledAppBar"
|
|
134
245
|
})(css({
|
|
135
246
|
boxShadow: `none`
|
|
136
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
247
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAkR4B","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
137
248
|
export const StyledNavBar = /*#__PURE__*/_styled("ul", {
|
|
138
249
|
target: "e1xddtpe0",
|
|
139
250
|
label: "StyledNavBar"
|
|
@@ -144,7 +255,7 @@ export const StyledNavBar = /*#__PURE__*/_styled("ul", {
|
|
|
144
255
|
listStyle: `none`,
|
|
145
256
|
margin: 0,
|
|
146
257
|
width: `100%`
|
|
147
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
258
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeader/shared/elements.tsx"],"names":[],"mappings":"AAwR4B","file":"../../../src/AppHeader/shared/elements.tsx","sourcesContent":["import {\n  Anchor,\n  FlexBox,\n  LayoutGrid,\n  Text,\n  WithChildrenProp,\n} from '@codecademy/gamut';\nimport { ArrowChevronDownFilledIcon } from '@codecademy/gamut-icons';\nimport {\n  Colors,\n  css,\n  pxRem,\n  states,\n  useCurrentMode,\n} from '@codecademy/gamut-styles';\nimport { StyleProps } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport {\n  AnimatePresence,\n  motion,\n  useReducedMotion,\n  Variants,\n} from 'framer-motion';\nimport * as React from 'react';\n\nimport { AppBar } from '../../AppBar';\nimport { GradientBackground } from '../AppHeaderElements/AppHeaderSection/elements';\n\nexport const appHeaderMobileBreakpoint = 'lg' as const;\n\nexport interface AnimatedHeaderZoneProps extends WithChildrenProp {\n  visible?: boolean;\n}\n\nconst animatedPopoverVariants: Variants = {\n  enter: { opacity: 1, transition: { duration: 0.2 } },\n  exit: { opacity: 0, transition: { duration: 0.2 } },\n};\n\nexport const useMegaMenuHeaderResponsiveStyles = (): {\n  bg: Colors;\n  borderColor: Colors;\n  color: Colors;\n} => {\n  const mode = useCurrentMode();\n\n  const bg = mode === 'dark' ? 'white' : 'navy-800';\n  const color = mode === 'dark' ? 'navy-900' : 'blue-0';\n\n  return { bg, borderColor: color, color };\n};\n\nexport const AnimatedHeaderZone: React.FC<AnimatedHeaderZoneProps> = ({\n  children,\n  visible,\n}) => {\n  return visible ? (\n    <AnimatePresence>\n      <motion.div\n        animate=\"enter\"\n        exit=\"exit\"\n        initial=\"exit\"\n        variants={animatedPopoverVariants}\n      >\n        {children}\n      </motion.div>\n    </AnimatePresence>\n  ) : null;\n};\n\nexport const DropdownAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    padding: `0.5rem 0`,\n    textAlign: `center`,\n    whiteSpace: `nowrap`,\n\n    '&:focus::before': {\n      opacity: 1,\n    },\n  })\n);\n\nconst dropdownStates = states({\n  open: {\n    transform: `rotate(-180deg)`,\n  },\n});\n\nexport const DropdownIcon = styled(ArrowChevronDownFilledIcon)<\n  StyleProps<typeof dropdownStates>\n>(\n  css({\n    marginLeft: pxRem(5),\n    transition: `transform 0.35s ease-out`,\n    transformOrigin: `center ${pxRem(5)}`,\n  }),\n  dropdownStates\n);\n\nexport const StyledText = styled(Text)(\n  css({\n    '&::after': {\n      display: `block`,\n      content: `attr(title)`,\n      fontWeight: `bold`,\n      height: `1px`,\n      color: `transparent`,\n      overflow: `hidden`,\n      visibility: `hidden`,\n    },\n  })\n);\n\nconst getDropdownAnimations = ({\n  prefersReducedMotion,\n  displayGlobalNavRedesign,\n}: {\n  prefersReducedMotion: boolean | null;\n  displayGlobalNavRedesign: boolean;\n}) => {\n  const transform = prefersReducedMotion ? 'none' : 'translateY(-8px)';\n\n  const dropdownAnimations = {\n    animate: {\n      transform: 'translateY(0)',\n      opacity: 1,\n    },\n    exit: { opacity: 0, transform },\n    initial: { opacity: 0, transform },\n    transition: { duration: 0.15, ease: 'easeOut' },\n  } as const;\n\n  const legacyDropdownAnimations = {\n    initial: { borderWidth: 0, height: 0 },\n    exit: { borderWidth: 0, height: 0 },\n    animate: {\n      borderWidth: 1,\n      height: 'fit-content',\n    },\n    transition: { duration: 0.175 },\n  } as const;\n\n  return displayGlobalNavRedesign\n    ? dropdownAnimations\n    : legacyDropdownAnimations;\n};\n\nconst MegaMenuDropdown = styled(motion.create('div'), {\n  shouldForwardProp: (prop) => prop !== 'displayGlobalNavRedesign',\n})<{\n  displayGlobalNavRedesign?: boolean;\n}>(({ displayGlobalNavRedesign }) =>\n  css({\n    bg: `background`,\n    overflow: `hidden`,\n    position: `absolute`,\n    ...(!displayGlobalNavRedesign\n      ? {\n          borderColor: 'border-primary',\n          borderStyle: 'solid',\n        }\n      : {}),\n  })\n);\n\nconst MegaMenuBackdrop = styled(motion.create('div'))(\n  css({\n    position: 'relative',\n    zIndex: -1,\n  })\n);\n\nexport const AnimatedMegaMenuDropdown = React.forwardRef(\n  (\n    {\n      isOpen,\n      displayGlobalNavRedesign = false,\n      ...props\n    }: React.ComponentProps<typeof MegaMenuDropdown> & {\n      isOpen: boolean;\n      displayGlobalNavRedesign?: boolean;\n    },\n    ref: React.ForwardedRef<HTMLDivElement>\n  ) => {\n    const prefersReducedMotion = useReducedMotion();\n\n    return (\n      <AnimatePresence>\n        {isOpen && (\n          <>\n            <MegaMenuBackdrop\n              {...(displayGlobalNavRedesign\n                ? {\n                    initial: { opacity: 0 },\n                    animate: { opacity: 1 },\n                    exit: { opacity: 0 },\n                    transition: { duration: 0.15, ease: 'easeOut' },\n                  }\n                : {})}\n            >\n              <GradientBackground\n                key=\"dropdown-backdrop\"\n                position=\"fixed\"\n                top=\"0\"\n                left=\"0\"\n                right=\"0\"\n                bottom=\"0\"\n              />\n            </MegaMenuBackdrop>\n            <MegaMenuDropdown\n              key=\"dropdown-content\"\n              {...getDropdownAnimations({\n                prefersReducedMotion,\n                displayGlobalNavRedesign,\n              })}\n              displayGlobalNavRedesign={displayGlobalNavRedesign}\n              ref={ref}\n              {...props}\n            />\n          </>\n        )}\n      </AnimatePresence>\n    );\n  }\n);\n\nconst SimpleDropdown = styled(motion.create('div'))(\n  css({\n    overflow: `hidden`,\n    position: `absolute`,\n  })\n);\n\nexport const AnimatedSimpleDropdown = ({\n  isOpen,\n  displayGlobalNavRedesign = false,\n  ...props\n}: React.ComponentProps<typeof MegaMenuDropdown> & {\n  isOpen: boolean;\n  displayGlobalNavRedesign?: boolean;\n}) => {\n  const prefersReducedMotion = useReducedMotion();\n\n  return (\n    <AnimatePresence>\n      {isOpen && (\n        <SimpleDropdown\n          {...getDropdownAnimations({\n            prefersReducedMotion,\n            displayGlobalNavRedesign,\n          })}\n          {...props}\n        />\n      )}\n    </AnimatePresence>\n  );\n};\n\nexport const LayoutGridAntiAliased = styled(LayoutGrid)`\n  -webkit-font-smoothing: antialiased;\n`;\n\n/* for Resources & Catalog menus */\nexport const DescriptionSectionContainer = styled(FlexBox)(\n  css({\n    '&:focus-visible': {\n      color: 'text',\n      outline: '1px solid currentColor !important',\n    },\n  })\n);\n\nexport const StyledAppBar = styled(AppBar)(\n  css({\n    boxShadow: `none`,\n  })\n);\n\nexport const StyledNavBar = styled.ul(\n  css({\n    alignItems: 'stretch',\n    display: `flex`,\n    padding: 0,\n    listStyle: `none`,\n    margin: 0,\n    width: `100%`,\n  })\n);\n\nexport const appHeaderSpacing = {\n  standard: 8,\n\n  enterprise: 12,\n} as const;\n"]} */");
|
|
148
259
|
export const appHeaderSpacing = {
|
|
149
260
|
standard: 8,
|
|
150
261
|
enterprise: 12
|