@codecademy/brand 4.2.1-alpha.90c3e1a4b.0 → 4.2.1-alpha.fdd012366.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.
@@ -7,7 +7,7 @@ import { css, theme } from '@codecademy/gamut-styles';
7
7
  import { forwardRef } from 'react';
8
8
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
9
9
  const CardAnchor = /*#__PURE__*/_styled(Anchor, {
10
- target: "e171y2mq4",
10
+ target: "e171y2mq5",
11
11
  label: "CardAnchor"
12
12
  })(css({
13
13
  display: 'flex',
@@ -17,35 +17,46 @@ const CardAnchor = /*#__PURE__*/_styled(Anchor, {
17
17
  color: 'text',
18
18
  textDecoration: 'none'
19
19
  }
20
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAOmB","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <FlexBox\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n            style={{\n              transform: 'translateY(-50%)',\n              pointerEvents: 'none',\n            }}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </FlexBox>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */");
20
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAOmB","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nconst PromotionBadgeWrapper = styled(FlexBox)`\n  transform: translateY(-50%);\n  pointer-events: none;\n`;\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <PromotionBadgeWrapper\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </PromotionBadgeWrapper>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */");
21
21
  const StyledImg = /*#__PURE__*/_styled("img", {
22
- target: "e171y2mq3",
22
+ target: "e171y2mq4",
23
23
  label: "StyledImg"
24
24
  })(process.env.NODE_ENV === "production" ? {
25
25
  name: "q5j908",
26
26
  styles: "width:100%;height:100%;object-fit:cover;display:block"
27
27
  } : {
28
28
  name: "q5j908",
29
- styles: "width:100%;height:100%;object-fit:cover;display:block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAmB4B","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <FlexBox\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n            style={{\n              transform: 'translateY(-50%)',\n              pointerEvents: 'none',\n            }}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </FlexBox>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */",
29
+ styles: "width:100%;height:100%;object-fit:cover;display:block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAmB4B","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nconst PromotionBadgeWrapper = styled(FlexBox)`\n  transform: translateY(-50%);\n  pointer-events: none;\n`;\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <PromotionBadgeWrapper\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </PromotionBadgeWrapper>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */",
30
30
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
31
  });
32
32
  const LastChanceBadge = /*#__PURE__*/_styled(Badge, {
33
- target: "e171y2mq2",
33
+ target: "e171y2mq3",
34
34
  label: "LastChanceBadge"
35
- })("color:", theme.colors.red, ";border-color:", theme.colors.red, ";background-color:", theme.colors['red-0'], ";border:1px solid ", theme.colors['red-500'], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AA0BqC","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <FlexBox\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n            style={{\n              transform: 'translateY(-50%)',\n              pointerEvents: 'none',\n            }}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </FlexBox>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */"));
35
+ })("color:", theme.colors.red, ";border-color:", theme.colors.red, ";background-color:", theme.colors['red-0'], ";border:1px solid ", theme.colors['red-500'], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AA0BqC","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nconst PromotionBadgeWrapper = styled(FlexBox)`\n  transform: translateY(-50%);\n  pointer-events: none;\n`;\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <PromotionBadgeWrapper\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </PromotionBadgeWrapper>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */"));
36
36
  const PromotionBadge = /*#__PURE__*/_styled(Badge, {
37
- target: "e171y2mq1",
37
+ target: "e171y2mq2",
38
38
  label: "PromotionBadge"
39
- })("color:", theme.colors.black, ";border-color:", theme.colors.yellow, ";background-color:", theme.colors['yellow-0'], ";border:1px solid ", theme.colors['yellow-500'], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAiCoC","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <FlexBox\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n            style={{\n              transform: 'translateY(-50%)',\n              pointerEvents: 'none',\n            }}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </FlexBox>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */"));
39
+ })("color:", theme.colors.black, ";border-color:", theme.colors.yellow, ";background-color:", theme.colors['yellow-0'], ";border:1px solid ", theme.colors['yellow-500'], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAiCoC","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nconst PromotionBadgeWrapper = styled(FlexBox)`\n  transform: translateY(-50%);\n  pointer-events: none;\n`;\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <PromotionBadgeWrapper\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </PromotionBadgeWrapper>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */"));
40
40
  const DottedLine = /*#__PURE__*/_styled(CheckerDense, {
41
- target: "e171y2mq0",
41
+ target: "e171y2mq1",
42
42
  label: "DottedLine"
43
43
  })(css({
44
44
  height: '1px',
45
45
  display: 'flex',
46
46
  position: 'absolute',
47
47
  marginTop: '-1px'
48
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAwCmB","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <FlexBox\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n            style={{\n              transform: 'translateY(-50%)',\n              pointerEvents: 'none',\n            }}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </FlexBox>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */");
48
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAwCmB","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nconst PromotionBadgeWrapper = styled(FlexBox)`\n  transform: translateY(-50%);\n  pointer-events: none;\n`;\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <PromotionBadgeWrapper\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </PromotionBadgeWrapper>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */");
49
+ const PromotionBadgeWrapper = /*#__PURE__*/_styled(FlexBox, {
50
+ target: "e171y2mq0",
51
+ label: "PromotionBadgeWrapper"
52
+ })(process.env.NODE_ENV === "production" ? {
53
+ name: "18tgdj7",
54
+ styles: "transform:translateY(-50%);pointer-events:none"
55
+ } : {
56
+ name: "18tgdj7",
57
+ styles: "transform:translateY(-50%);pointer-events:none/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/InstructorCard/index.tsx"],"names":[],"mappings":"AAiD6C","file":"../../src/InstructorCard/index.tsx","sourcesContent":["import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { forwardRef, PropsWithRef } from 'react';\n\nconst CardAnchor = styled(Anchor)(\n  css({\n    display: 'flex',\n    flexDirection: 'column',\n    height: '100%',\n    '&:hover, &:focus, &:focus-visible': {\n      color: 'text',\n      textDecoration: 'none',\n    },\n  })\n);\n\nconst StyledImg = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  display: block;\n`;\n\nconst LastChanceBadge = styled(Badge)`\n  color: ${theme.colors.red};\n  border-color: ${theme.colors.red};\n  background-color: ${theme.colors['red-0']};\n  border: 1px solid ${theme.colors['red-500']};\n`;\n\nconst PromotionBadge = styled(Badge)`\n  color: ${theme.colors.black};\n  border-color: ${theme.colors.yellow};\n  background-color: ${theme.colors['yellow-0']};\n  border: 1px solid ${theme.colors['yellow-500']};\n`;\n\nconst DottedLine = styled(CheckerDense)(\n  css({\n    height: '1px',\n    display: 'flex',\n    position: 'absolute',\n    marginTop: '-1px',\n  })\n);\n\nconst PromotionBadgeWrapper = styled(FlexBox)`\n  transform: translateY(-50%);\n  pointer-events: none;\n`;\n\nexport const Divider: React.FC = () => {\n  return (\n    // the height and position properties are necessary for iOS devices\n    <Box py={4} height={0} position=\"relative\" aria-hidden>\n      <DottedLine />\n    </Box>\n  );\n};\n\ntype InfoRowProps = {\n  icon: React.ReactNode;\n  children: React.ReactNode;\n};\n\nconst InfoRow: React.FC<InfoRowProps> = ({ icon, children }) => (\n  <FlexBox alignItems=\"center\" gap={8}>\n    {icon}\n    <Text fontSize={14} lineHeight=\"base\" color=\"text\">\n      {children}\n    </Text>\n  </FlexBox>\n);\n\nexport type InstructorCardProps = {\n  /** The bootcamp title */\n  title: string;\n  /** Instructor's full name */\n  instructorName: string;\n  /** Instructor's professional title */\n  instructorTitle: string;\n  /** URL for the instructor's profile pic (includes background gradient) */\n  instructorImageUrl?: string;\n  /** Formatted start date for the next cohort (e.g. \"Feb 10\") */\n  nextCohortStartDate?: string;\n  /**\n   * Promotional label from the latest cohort (e.g. \"Last chance - 20% off\").\n   * Rendered centered on the top edge of the card, overlapping the border.\n   */\n  promotionBadgeLabel?: string;\n  /** Link destination */\n  href: string;\n  /** Click handler */\n  onClick: () => void;\n};\n\nexport const InstructorCard = forwardRef<\n  HTMLAnchorElement,\n  PropsWithRef<InstructorCardProps>\n>(\n  (\n    {\n      title,\n      instructorName,\n      instructorTitle,\n      instructorImageUrl,\n      nextCohortStartDate,\n      promotionBadgeLabel,\n      href,\n      onClick,\n    },\n    ref\n  ) => {\n    const isLastChance = promotionBadgeLabel\n      ?.toLowerCase()\n      .includes('last chance');\n\n    const PromotionBadgeComponent = isLastChance\n      ? LastChanceBadge\n      : PromotionBadge;\n\n    return (\n      <Box position=\"relative\" width=\"100%\" height=\"100%\">\n        {promotionBadgeLabel ? (\n          <PromotionBadgeWrapper\n            justifyContent=\"center\"\n            position=\"absolute\"\n            left={0}\n            right={0}\n            top={0}\n            zIndex={2}\n          >\n            <PromotionBadgeComponent variant=\"tertiary\" size=\"base\">\n              {promotionBadgeLabel}\n            </PromotionBadgeComponent>\n          </PromotionBadgeWrapper>\n        ) : null}\n        <Card\n          borderRadius=\"md\"\n          borderColor=\"border-primary\"\n          overflow=\"hidden\"\n          display=\"flex\"\n          flexDirection=\"column\"\n          isInteractive\n          p={0}\n          height=\"100%\"\n          width=\"100%\"\n        >\n          <CardAnchor\n            href={href}\n            onClick={onClick}\n            variant=\"interface\"\n            ref={ref}\n          >\n            <Box\n              width=\"100%\"\n              height={160}\n              position=\"relative\"\n              overflow=\"hidden\"\n              bg=\"navy-800\"\n            >\n              {instructorImageUrl && (\n                <StyledImg src={instructorImageUrl} alt={instructorName} />\n              )}\n            </Box>\n\n            <FlexBox\n              flexDirection=\"column\"\n              flex={1}\n              pt={12}\n              pb={4}\n              px={12}\n              overflow=\"hidden\"\n            >\n              <FlexBox\n                flexDirection=\"column\"\n                alignSelf=\"stretch\"\n                flex={1}\n                gap={4}\n              >\n                <Text\n                  as=\"h3\"\n                  fontSize={20}\n                  fontWeight=\"bold\"\n                  lineHeight=\"title\"\n                  color=\"text\"\n                  m={0}\n                  truncate=\"ellipsis\"\n                  truncateLines={3}\n                >\n                  {title}\n                </Text>\n\n                <FlexBox flexDirection=\"column\" gap={4} mt=\"auto\" minWidth={0}>\n                  <Text\n                    fontSize={14}\n                    fontWeight=\"bold\"\n                    lineHeight=\"base\"\n                    color=\"text\"\n                  >\n                    {instructorName}\n                  </Text>\n                  <Text\n                    fontSize={14}\n                    lineHeight=\"base\"\n                    color=\"text-secondary\"\n                    truncate=\"ellipsis\"\n                    truncateLines={1}\n                    width=\"100%\"\n                  >\n                    {instructorTitle}\n                  </Text>\n                </FlexBox>\n              </FlexBox>\n\n              <FlexBox flexDirection=\"column\" alignSelf=\"stretch\" mt={4}>\n                {nextCohortStartDate && (\n                  <>\n                    <Divider />\n                    <InfoRow icon={<CalendarIcon size={16} aria-hidden />}>\n                      Next cohort: Starts{' '}\n                      <Text as=\"span\" fontWeight=\"bold\">\n                        {nextCohortStartDate}\n                      </Text>\n                    </InfoRow>\n                  </>\n                )}\n                <Divider />\n                <InfoRow icon={<CertificateIcon size={16} aria-hidden />}>\n                  With{' '}\n                  <Text as=\"span\" fontWeight=\"bold\">\n                    Certificate\n                  </Text>\n                </InfoRow>\n              </FlexBox>\n            </FlexBox>\n          </CardAnchor>\n        </Card>\n      </Box>\n    );\n  }\n);\n"]} */",
58
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
+ });
49
60
  export const Divider = () => {
50
61
  return (
51
62
  /*#__PURE__*/
@@ -88,17 +99,13 @@ export const InstructorCard = /*#__PURE__*/forwardRef(({
88
99
  position: "relative",
89
100
  width: "100%",
90
101
  height: "100%",
91
- children: [promotionBadgeLabel ? /*#__PURE__*/_jsx(FlexBox, {
102
+ children: [promotionBadgeLabel ? /*#__PURE__*/_jsx(PromotionBadgeWrapper, {
92
103
  justifyContent: "center",
93
104
  position: "absolute",
94
105
  left: 0,
95
106
  right: 0,
96
107
  top: 0,
97
108
  zIndex: 2,
98
- style: {
99
- transform: 'translateY(-50%)',
100
- pointerEvents: 'none'
101
- },
102
109
  children: /*#__PURE__*/_jsx(PromotionBadgeComponent, {
103
110
  variant: "tertiary",
104
111
  size: "base",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@codecademy/brand",
3
- "version": "4.2.1-alpha.90c3e1a4b.0",
3
+ "version": "4.2.1-alpha.fdd012366.0",
4
4
  "description": "Brand component library for Codecademy",
5
5
  "license": "MIT",
6
6
  "repository": "git@github.com:codecademy-engineering/mono.git",