@codecademy/brand 4.2.0 → 4.2.1-alpha.21bfd035d.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.
|
@@ -10,6 +10,11 @@ export type InstructorCardProps = {
|
|
|
10
10
|
instructorImageUrl?: string;
|
|
11
11
|
/** Formatted start date for the next cohort (e.g. "Feb 10") */
|
|
12
12
|
nextCohortStartDate?: string;
|
|
13
|
+
/**
|
|
14
|
+
* Promotional label from the latest cohort (e.g. "Last chance - 20% off").
|
|
15
|
+
* Rendered centered on the top edge of the card, overlapping the border.
|
|
16
|
+
*/
|
|
17
|
+
promotionBadgeLabel?: string;
|
|
13
18
|
/** Link destination */
|
|
14
19
|
href: string;
|
|
15
20
|
/** Click handler */
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
2
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
3
|
-
import { Anchor, Box, Card, FlexBox, Text } from '@codecademy/gamut';
|
|
3
|
+
import { Anchor, Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';
|
|
4
4
|
import { CalendarIcon, CertificateIcon } from '@codecademy/gamut-icons';
|
|
5
5
|
import { CheckerDense } from '@codecademy/gamut-patterns';
|
|
6
|
-
import { css } from '@codecademy/gamut-styles';
|
|
6
|
+
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: "
|
|
10
|
+
target: "e171y2mq4",
|
|
11
11
|
label: "CardAnchor"
|
|
12
12
|
})(css({
|
|
13
13
|
display: 'flex',
|
|
@@ -17,18 +17,26 @@ 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,
|
|
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"]} */");
|
|
21
21
|
const StyledImg = /*#__PURE__*/_styled("img", {
|
|
22
|
-
target: "
|
|
22
|
+
target: "e171y2mq3",
|
|
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,
|
|
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"]} */",
|
|
30
30
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
31
31
|
});
|
|
32
|
+
const LastChanceBadge = /*#__PURE__*/_styled(Badge, {
|
|
33
|
+
target: "e171y2mq2",
|
|
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"]} */"));
|
|
36
|
+
const PromotionBadge = /*#__PURE__*/_styled(Badge, {
|
|
37
|
+
target: "e171y2mq1",
|
|
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"]} */"));
|
|
32
40
|
const DottedLine = /*#__PURE__*/_styled(CheckerDense, {
|
|
33
41
|
target: "e171y2mq0",
|
|
34
42
|
label: "DottedLine"
|
|
@@ -37,7 +45,7 @@ const DottedLine = /*#__PURE__*/_styled(CheckerDense, {
|
|
|
37
45
|
display: 'flex',
|
|
38
46
|
position: 'absolute',
|
|
39
47
|
marginTop: '-1px'
|
|
40
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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"]} */");
|
|
41
49
|
export const Divider = () => {
|
|
42
50
|
return (
|
|
43
51
|
/*#__PURE__*/
|
|
@@ -70,106 +78,130 @@ export const InstructorCard = /*#__PURE__*/forwardRef(({
|
|
|
70
78
|
instructorTitle,
|
|
71
79
|
instructorImageUrl,
|
|
72
80
|
nextCohortStartDate,
|
|
81
|
+
promotionBadgeLabel,
|
|
73
82
|
href,
|
|
74
83
|
onClick
|
|
75
84
|
}, ref) => {
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
display: "flex",
|
|
81
|
-
flexDirection: "column",
|
|
82
|
-
isInteractive: true,
|
|
83
|
-
p: 0,
|
|
84
|
-
height: "100%",
|
|
85
|
+
const isLastChance = promotionBadgeLabel?.toLowerCase().includes('last chance');
|
|
86
|
+
const PromotionBadgeComponent = isLastChance ? LastChanceBadge : PromotionBadge;
|
|
87
|
+
return /*#__PURE__*/_jsxs(Box, {
|
|
88
|
+
position: "relative",
|
|
85
89
|
width: "100%",
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
90
|
+
height: "100%",
|
|
91
|
+
children: [promotionBadgeLabel ? /*#__PURE__*/_jsx(FlexBox, {
|
|
92
|
+
justifyContent: "center",
|
|
93
|
+
position: "absolute",
|
|
94
|
+
left: 0,
|
|
95
|
+
right: 0,
|
|
96
|
+
top: 0,
|
|
97
|
+
zIndex: 2,
|
|
98
|
+
style: {
|
|
99
|
+
transform: 'translateY(-50%)',
|
|
100
|
+
pointerEvents: 'none'
|
|
101
|
+
},
|
|
102
|
+
children: /*#__PURE__*/_jsx(PromotionBadgeComponent, {
|
|
103
|
+
variant: "tertiary",
|
|
104
|
+
size: "base",
|
|
105
|
+
children: promotionBadgeLabel
|
|
106
|
+
})
|
|
107
|
+
}) : null, /*#__PURE__*/_jsx(Card, {
|
|
108
|
+
borderRadius: "md",
|
|
109
|
+
borderColor: "border-primary",
|
|
110
|
+
overflow: "hidden",
|
|
111
|
+
display: "flex",
|
|
112
|
+
flexDirection: "column",
|
|
113
|
+
isInteractive: true,
|
|
114
|
+
p: 0,
|
|
115
|
+
height: "100%",
|
|
116
|
+
width: "100%",
|
|
117
|
+
children: /*#__PURE__*/_jsxs(CardAnchor, {
|
|
118
|
+
href: href,
|
|
119
|
+
onClick: onClick,
|
|
120
|
+
variant: "interface",
|
|
121
|
+
ref: ref,
|
|
122
|
+
children: [/*#__PURE__*/_jsx(Box, {
|
|
123
|
+
width: "100%",
|
|
124
|
+
height: 160,
|
|
125
|
+
position: "relative",
|
|
126
|
+
overflow: "hidden",
|
|
127
|
+
bg: "navy-800",
|
|
128
|
+
children: instructorImageUrl && /*#__PURE__*/_jsx(StyledImg, {
|
|
129
|
+
src: instructorImageUrl,
|
|
130
|
+
alt: instructorName
|
|
131
|
+
})
|
|
132
|
+
}), /*#__PURE__*/_jsxs(FlexBox, {
|
|
109
133
|
flexDirection: "column",
|
|
110
|
-
alignSelf: "stretch",
|
|
111
134
|
flex: 1,
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
lineHeight: "title",
|
|
118
|
-
color: "text",
|
|
119
|
-
m: 0,
|
|
120
|
-
truncate: "ellipsis",
|
|
121
|
-
truncateLines: 3,
|
|
122
|
-
children: title
|
|
123
|
-
}), /*#__PURE__*/_jsxs(FlexBox, {
|
|
135
|
+
pt: 12,
|
|
136
|
+
pb: 4,
|
|
137
|
+
px: 12,
|
|
138
|
+
overflow: "hidden",
|
|
139
|
+
children: [/*#__PURE__*/_jsxs(FlexBox, {
|
|
124
140
|
flexDirection: "column",
|
|
141
|
+
alignSelf: "stretch",
|
|
142
|
+
flex: 1,
|
|
125
143
|
gap: 4,
|
|
126
|
-
mt: "auto",
|
|
127
|
-
minWidth: 0,
|
|
128
144
|
children: [/*#__PURE__*/_jsx(Text, {
|
|
129
|
-
|
|
145
|
+
as: "h3",
|
|
146
|
+
fontSize: 20,
|
|
130
147
|
fontWeight: "bold",
|
|
131
|
-
lineHeight: "
|
|
148
|
+
lineHeight: "title",
|
|
132
149
|
color: "text",
|
|
133
|
-
|
|
134
|
-
}), /*#__PURE__*/_jsx(Text, {
|
|
135
|
-
fontSize: 14,
|
|
136
|
-
lineHeight: "base",
|
|
137
|
-
color: "text-secondary",
|
|
150
|
+
m: 0,
|
|
138
151
|
truncate: "ellipsis",
|
|
139
|
-
truncateLines:
|
|
140
|
-
|
|
141
|
-
|
|
152
|
+
truncateLines: 3,
|
|
153
|
+
children: title
|
|
154
|
+
}), /*#__PURE__*/_jsxs(FlexBox, {
|
|
155
|
+
flexDirection: "column",
|
|
156
|
+
gap: 4,
|
|
157
|
+
mt: "auto",
|
|
158
|
+
minWidth: 0,
|
|
159
|
+
children: [/*#__PURE__*/_jsx(Text, {
|
|
160
|
+
fontSize: 14,
|
|
161
|
+
fontWeight: "bold",
|
|
162
|
+
lineHeight: "base",
|
|
163
|
+
color: "text",
|
|
164
|
+
children: instructorName
|
|
165
|
+
}), /*#__PURE__*/_jsx(Text, {
|
|
166
|
+
fontSize: 14,
|
|
167
|
+
lineHeight: "base",
|
|
168
|
+
color: "text-secondary",
|
|
169
|
+
truncate: "ellipsis",
|
|
170
|
+
truncateLines: 1,
|
|
171
|
+
width: "100%",
|
|
172
|
+
children: instructorTitle
|
|
173
|
+
})]
|
|
142
174
|
})]
|
|
143
|
-
})
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
175
|
+
}), /*#__PURE__*/_jsxs(FlexBox, {
|
|
176
|
+
flexDirection: "column",
|
|
177
|
+
alignSelf: "stretch",
|
|
178
|
+
mt: 4,
|
|
179
|
+
children: [nextCohortStartDate && /*#__PURE__*/_jsxs(_Fragment, {
|
|
180
|
+
children: [/*#__PURE__*/_jsx(Divider, {}), /*#__PURE__*/_jsxs(InfoRow, {
|
|
181
|
+
icon: /*#__PURE__*/_jsx(CalendarIcon, {
|
|
182
|
+
size: 16,
|
|
183
|
+
"aria-hidden": true
|
|
184
|
+
}),
|
|
185
|
+
children: ["Next cohort: Starts", ' ', /*#__PURE__*/_jsx(Text, {
|
|
186
|
+
as: "span",
|
|
187
|
+
fontWeight: "bold",
|
|
188
|
+
children: nextCohortStartDate
|
|
189
|
+
})]
|
|
190
|
+
})]
|
|
191
|
+
}), /*#__PURE__*/_jsx(Divider, {}), /*#__PURE__*/_jsxs(InfoRow, {
|
|
192
|
+
icon: /*#__PURE__*/_jsx(CertificateIcon, {
|
|
151
193
|
size: 16,
|
|
152
194
|
"aria-hidden": true
|
|
153
195
|
}),
|
|
154
|
-
children: ["
|
|
196
|
+
children: ["With", ' ', /*#__PURE__*/_jsx(Text, {
|
|
155
197
|
as: "span",
|
|
156
198
|
fontWeight: "bold",
|
|
157
|
-
children:
|
|
199
|
+
children: "Certificate"
|
|
158
200
|
})]
|
|
159
201
|
})]
|
|
160
|
-
}), /*#__PURE__*/_jsx(Divider, {}), /*#__PURE__*/_jsxs(InfoRow, {
|
|
161
|
-
icon: /*#__PURE__*/_jsx(CertificateIcon, {
|
|
162
|
-
size: 16,
|
|
163
|
-
"aria-hidden": true
|
|
164
|
-
}),
|
|
165
|
-
children: ["With", ' ', /*#__PURE__*/_jsx(Text, {
|
|
166
|
-
as: "span",
|
|
167
|
-
fontWeight: "bold",
|
|
168
|
-
children: "Certificate"
|
|
169
|
-
})]
|
|
170
202
|
})]
|
|
171
203
|
})]
|
|
172
|
-
})
|
|
173
|
-
})
|
|
204
|
+
})
|
|
205
|
+
})]
|
|
174
206
|
});
|
|
175
207
|
});
|
|
@@ -63,6 +63,17 @@ export const InstructorCardWithoutNextCohort = {
|
|
|
63
63
|
}),
|
|
64
64
|
name: 'InstructorCard without Next Cohort'
|
|
65
65
|
};
|
|
66
|
+
export const InstructorCardWithPromotionBadge = {
|
|
67
|
+
render: args => /*#__PURE__*/_jsx(Box, {
|
|
68
|
+
pb: 8,
|
|
69
|
+
pt: 16,
|
|
70
|
+
children: /*#__PURE__*/_jsx(InstructorCard, {
|
|
71
|
+
...args,
|
|
72
|
+
promotionBadgeLabel: "Last chance - 20% off"
|
|
73
|
+
})
|
|
74
|
+
}),
|
|
75
|
+
name: 'InstructorCard with promotion badge'
|
|
76
|
+
};
|
|
66
77
|
export const InstructorCardGrid = {
|
|
67
78
|
render: args => /*#__PURE__*/_jsxs(LayoutGrid, {
|
|
68
79
|
gap: 24,
|
package/package.json
CHANGED