@codecademy/brand 3.11.0 → 3.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/PricingSection/PricingCard/index.d.ts +5 -1
- package/dist/PricingSection/PricingCard/index.js +8 -6
- package/dist/PricingSection/ProductCTA.d.ts +5 -1
- package/dist/PricingSection/ProductCTA.js +27 -1
- package/dist/PricingSection/Products.d.ts +4 -0
- package/dist/PricingSection/Products.js +6 -3
- package/dist/PricingSection/index.d.ts +4 -0
- package/dist/PricingSection/index.js +4 -2
- package/package.json +1 -1
|
@@ -2,11 +2,15 @@ import { PlansByType } from '../config';
|
|
|
2
2
|
import { Product, ProductDetails, User } from '../types';
|
|
3
3
|
import { AllCurrency } from './types';
|
|
4
4
|
export declare const smSize = 728;
|
|
5
|
-
export declare const PricingCard: ({ product, productDetails, currency, plansByType, isUserInIndia, user, }: {
|
|
5
|
+
export declare const PricingCard: ({ product, productDetails, currency, plansByType, isUserInIndia, user, trackBusinessClick, }: {
|
|
6
6
|
product: Product;
|
|
7
7
|
productDetails: ProductDetails;
|
|
8
8
|
currency: AllCurrency;
|
|
9
9
|
plansByType: PlansByType;
|
|
10
10
|
isUserInIndia: boolean;
|
|
11
11
|
user: User;
|
|
12
|
+
trackBusinessClick?: ({ target, context, }: {
|
|
13
|
+
target: string;
|
|
14
|
+
context: string;
|
|
15
|
+
}) => void;
|
|
12
16
|
}) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -19,17 +19,17 @@ const StyledCard = /*#__PURE__*/_styled(Card, {
|
|
|
19
19
|
padding: 0,
|
|
20
20
|
width: '100%',
|
|
21
21
|
flexDirection: 'column'
|
|
22
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZW1CIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYWRnZSwgQm94LCBDYXJkLCBGbGV4Qm94LCBUZXh0IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQnO1xuaW1wb3J0IHsgQ2hlY2tlckRlbnNlIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtcGF0dGVybnMnO1xuaW1wb3J0IHsgY3NzLCBweFJlbSwgdGhlbWUsIHZhcmlhbnQgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5pbXBvcnQgeyBDb25kaXRpb25hbENvbG9yTW9kZSB9IGZyb20gJy4uL0NvbmRpdGlvbmFsQ29sb3JNb2RlJztcbmltcG9ydCB7IGdldFByb2R1Y3REZXNjcmlwdGlvbiwgUGxhbnNCeVR5cGUgfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvZHVjdENUQSB9IGZyb20gJy4uL1Byb2R1Y3RDVEEnO1xuaW1wb3J0IHsgUHJvZHVjdCwgUHJvZHVjdERldGFpbHMsIFVzZXIgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBQcmljaW5nQW1vdW50IH0gZnJvbSAnLi9QcmljaW5nQW1vdW50JztcbmltcG9ydCB7IFJlY29tbWVuZGVkQmFkZ2UgfSBmcm9tICcuL1JlY29tbWVuZGVkQmFkZ2UnO1xuaW1wb3J0IHsgQWxsQ3VycmVuY3kgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IHNtU2l6ZSA9IDcyODtcblxuY29uc3QgU3R5bGVkQ2FyZCA9IHN0eWxlZChDYXJkKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6IDEsXG4gICAgYm9yZGVyV2lkdGg6IDAsXG4gICAgcGFkZGluZzogMCxcbiAgICB3aWR0aDogJzEwMCUnLFxuICAgIGZsZXhEaXJlY3Rpb246ICdjb2x1bW4nLFxuICB9KVxuKTtcblxuY29uc3QgRGl2aWRlciA9IHN0eWxlZChDaGVja2VyRGVuc2UpKFxuICBjc3Moe1xuICAgIGhlaWdodDogJzAuMXJlbScsXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZExpc3RSb3dQcm9wcyA9IHtcbiAgc2hvd1JlY29tbWVuZGVkQmFkZ2U6IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRMaXN0Um93ID0gc3R5bGVkKCdsaScpPFN0eWxlZExpc3RSb3dQcm9wcz5gXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6ICR7cHhSZW0oc21TaXplKX07XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgJHt0aGVtZS5icmVha3BvaW50cy5sZ30ge1xuICAgIG1pbi13aWR0aDogMzZyZW07XG4gIH1cbmA7XG5cbmNvbnN0IGNhcmRIZWFkZXJWYXJpYW50cyA9IHZhcmlhbnQoe1xuICBiYXNlOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAndHJhbnNwYXJlbnQnLFxuICB9LFxuICB2YXJpYW50czoge1xuICAgIFtQcm9kdWN0LkJhc2ljXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LkVudGVycHJpc2VdOiB7XG4gICAgICBib3JkZXJCb3R0b21XaWR0aDogMSxcbiAgICAgIGJvcmRlckJvdHRvbVN0eWxlOiAnc29saWQnLFxuICAgICAgYm9yZGVyQm90dG9tQ29sb3I6IHRoZW1lLmNvbG9yc1snbmF2eS0yMDAnXSxcbiAgICAgIGNvbG9yOiAnbmF2eS01MDAnLFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuU2lsdmVyXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMucGFsZVllbGxvdyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LkdvbGRdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy55ZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Qcm9dOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy55ZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5UZWFtc106IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLmJhY2tncm91bmQsXG4gICAgfSxcbiAgfSxcbn0pO1xuXG5jb25zdCBDYXJkSGVhZGVyID0gc3R5bGVkKEZsZXhCb3gpKGNhcmRIZWFkZXJWYXJpYW50cyk7XG5cbmNvbnN0IGdldEJhZGdlVGV4dCA9IChwcm9kdWN0OiBQcm9kdWN0KTogc3RyaW5nIHwgbnVsbCA9PiB7XG4gIHN3aXRjaCAocHJvZHVjdCkge1xuICAgIGNhc2UgUHJvZHVjdC5Hb2xkOlxuICAgICAgcmV0dXJuICdBZHZhbmNlIHlvdXIgY2FyZWVyJztcbiAgICBjYXNlIFByb2R1Y3QuU2lsdmVyOlxuICAgIGNhc2UgUHJvZHVjdC5Qcm86XG4gICAgICByZXR1cm4gJ0xlYXJuIGEgc2tpbGwnO1xuICAgIGNhc2UgUHJvZHVjdC5UZWFtczpcbiAgICAgIHJldHVybiAnUmVjb21tZW5kZWQgZm9yIDIrJztcbiAgICBjYXNlIFByb2R1Y3QuRW50ZXJwcmlzZTpcbiAgICAgIHJldHVybiAnUmVjb21tZW5kZWQgZm9yIDI1Kyc7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBudWxsO1xuICB9XG59O1xuXG5jb25zdCByZW5kZXJQcm9kdWN0RGVzY3JpcHRpb24gPSAocHJvZHVjdDogUHJvZHVjdCkgPT4ge1xuICBjb25zdCBwcm9kdWN0RmVhdHVyZXMgPSAoXG4gICAgPFRleHQgbWF4V2lkdGg9e3sgbWQ6ICcyMzVweCcgfX0gdGV4dEFsaWduPVwiY2VudGVyXCI+XG4gICAgICB7Z2V0UHJvZHVjdERlc2NyaXB0aW9uKHByb2R1Y3QpfVxuICAgIDwvVGV4dD5cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxGbGV4Qm94IG10PXs4fSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgZmxleERpcmVjdGlvbj1cImNvbHVtblwiPlxuICAgICAge3Byb2R1Y3RGZWF0dXJlc31cbiAgICA8L0ZsZXhCb3g+
|
|
22
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AAemB","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n  trackBusinessClick,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n  trackBusinessClick?: ({\n    target,\n    context,\n  }: {\n    target: string;\n    context: string;\n  }) => void;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n            trackBusinessClick={trackBusinessClick}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */");
|
|
23
23
|
const Divider = /*#__PURE__*/_styled(CheckerDense, {
|
|
24
24
|
target: "e3n4z5j2",
|
|
25
25
|
label: "Divider"
|
|
26
26
|
})(css({
|
|
27
27
|
height: '0.1rem'
|
|
28
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJnQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUHJpY2luZ1NlY3Rpb24vUHJpY2luZ0NhcmQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IENoZWNrZXJEZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IGNzcywgcHhSZW0sIHRoZW1lLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQ29uZGl0aW9uYWxDb2xvck1vZGUgfSBmcm9tICcuLi9Db25kaXRpb25hbENvbG9yTW9kZSc7XG5pbXBvcnQgeyBnZXRQcm9kdWN0RGVzY3JpcHRpb24sIFBsYW5zQnlUeXBlIH0gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7IFByb2R1Y3RDVEEgfSBmcm9tICcuLi9Qcm9kdWN0Q1RBJztcbmltcG9ydCB7IFByb2R1Y3QsIFByb2R1Y3REZXRhaWxzLCBVc2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgUHJpY2luZ0Ftb3VudCB9IGZyb20gJy4vUHJpY2luZ0Ftb3VudCc7XG5pbXBvcnQgeyBSZWNvbW1lbmRlZEJhZGdlIH0gZnJvbSAnLi9SZWNvbW1lbmRlZEJhZGdlJztcbmltcG9ydCB7IEFsbEN1cnJlbmN5IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBzbVNpemUgPSA3Mjg7XG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQoQ2FyZCkoXG4gIGNzcyh7XG4gICAgaGVpZ2h0OiAxLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6ICcxMDAlJyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgfSlcbik7XG5cbmNvbnN0IERpdmlkZXIgPSBzdHlsZWQoQ2hlY2tlckRlbnNlKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6ICcwLjFyZW0nLFxuICB9KVxuKTtcblxudHlwZSBTdHlsZWRMaXN0Um93UHJvcHMgPSB7XG4gIHNob3dSZWNvbW1lbmRlZEJhZGdlOiBib29sZWFuO1xufTtcblxuY29uc3QgU3R5bGVkTGlzdFJvdyA9IHN0eWxlZCgnbGknKTxTdHlsZWRMaXN0Um93UHJvcHM+YFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiAke3B4UmVtKHNtU2l6ZSl9O1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7dGhlbWUuYnJlYWtwb2ludHMubGd9IHtcbiAgICBtaW4td2lkdGg6IDM2cmVtO1xuICB9XG5gO1xuXG5jb25zdCBjYXJkSGVhZGVyVmFyaWFudHMgPSB2YXJpYW50KHtcbiAgYmFzZToge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgfSxcbiAgdmFyaWFudHM6IHtcbiAgICBbUHJvZHVjdC5CYXNpY106IHtcbiAgICAgIGJvcmRlckJvdHRvbVdpZHRoOiAxLFxuICAgICAgYm9yZGVyQm90dG9tU3R5bGU6ICdzb2xpZCcsXG4gICAgICBib3JkZXJCb3R0b21Db2xvcjogdGhlbWUuY29sb3JzWyduYXZ5LTIwMCddLFxuICAgICAgY29sb3I6ICduYXZ5LTUwMCcsXG4gICAgfSxcbiAgICBbUHJvZHVjdC5FbnRlcnByaXNlXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LlNpbHZlcl06IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLnBhbGVZZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Hb2xkXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuUHJvXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuVGVhbXNdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kLFxuICAgIH0sXG4gIH0sXG59KTtcblxuY29uc3QgQ2FyZEhlYWRlciA9IHN0eWxlZChGbGV4Qm94KShjYXJkSGVhZGVyVmFyaWFudHMpO1xuXG5jb25zdCBnZXRCYWRnZVRleHQgPSAocHJvZHVjdDogUHJvZHVjdCk6IHN0cmluZyB8IG51bGwgPT4ge1xuICBzd2l0Y2ggKHByb2R1Y3QpIHtcbiAgICBjYXNlIFByb2R1Y3QuR29sZDpcbiAgICAgIHJldHVybiAnQWR2YW5jZSB5b3VyIGNhcmVlcic7XG4gICAgY2FzZSBQcm9kdWN0LlNpbHZlcjpcbiAgICBjYXNlIFByb2R1Y3QuUHJvOlxuICAgICAgcmV0dXJuICdMZWFybiBhIHNraWxsJztcbiAgICBjYXNlIFByb2R1Y3QuVGVhbXM6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyKyc7XG4gICAgY2FzZSBQcm9kdWN0LkVudGVycHJpc2U6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyNSsnO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gbnVsbDtcbiAgfVxufTtcblxuY29uc3QgcmVuZGVyUHJvZHVjdERlc2NyaXB0aW9uID0gKHByb2R1Y3Q6IFByb2R1Y3QpID0+IHtcbiAgY29uc3QgcHJvZHVjdEZlYXR1cmVzID0gKFxuICAgIDxUZXh0IG1heFdpZHRoPXt7IG1kOiAnMjM1cHgnIH19IHRleHRBbGlnbj1cImNlbnRlclwiPlxuICAgICAge2dldFByb2R1Y3REZXNjcmlwdGlvbihwcm9kdWN0KX1cbiAgICA8L1RleHQ+
|
|
28
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AAyBgB","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n  trackBusinessClick,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n  trackBusinessClick?: ({\n    target,\n    context,\n  }: {\n    target: string;\n    context: string;\n  }) => void;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n            trackBusinessClick={trackBusinessClick}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */");
|
|
29
29
|
const StyledListRow = /*#__PURE__*/_styled('li', {
|
|
30
30
|
target: "e3n4z5j1",
|
|
31
31
|
label: "StyledListRow"
|
|
32
|
-
})("width:100%;max-width:", pxRem(smSize), ";height:100%;display:grid;", theme.breakpoints.lg, "{min-width:36rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUNzRCIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUHJpY2luZ1NlY3Rpb24vUHJpY2luZ0NhcmQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IENoZWNrZXJEZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IGNzcywgcHhSZW0sIHRoZW1lLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQ29uZGl0aW9uYWxDb2xvck1vZGUgfSBmcm9tICcuLi9Db25kaXRpb25hbENvbG9yTW9kZSc7XG5pbXBvcnQgeyBnZXRQcm9kdWN0RGVzY3JpcHRpb24sIFBsYW5zQnlUeXBlIH0gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7IFByb2R1Y3RDVEEgfSBmcm9tICcuLi9Qcm9kdWN0Q1RBJztcbmltcG9ydCB7IFByb2R1Y3QsIFByb2R1Y3REZXRhaWxzLCBVc2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgUHJpY2luZ0Ftb3VudCB9IGZyb20gJy4vUHJpY2luZ0Ftb3VudCc7XG5pbXBvcnQgeyBSZWNvbW1lbmRlZEJhZGdlIH0gZnJvbSAnLi9SZWNvbW1lbmRlZEJhZGdlJztcbmltcG9ydCB7IEFsbEN1cnJlbmN5IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBzbVNpemUgPSA3Mjg7XG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQoQ2FyZCkoXG4gIGNzcyh7XG4gICAgaGVpZ2h0OiAxLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6ICcxMDAlJyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgfSlcbik7XG5cbmNvbnN0IERpdmlkZXIgPSBzdHlsZWQoQ2hlY2tlckRlbnNlKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6ICcwLjFyZW0nLFxuICB9KVxuKTtcblxudHlwZSBTdHlsZWRMaXN0Um93UHJvcHMgPSB7XG4gIHNob3dSZWNvbW1lbmRlZEJhZGdlOiBib29sZWFuO1xufTtcblxuY29uc3QgU3R5bGVkTGlzdFJvdyA9IHN0eWxlZCgnbGknKTxTdHlsZWRMaXN0Um93UHJvcHM+YFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiAke3B4UmVtKHNtU2l6ZSl9O1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7dGhlbWUuYnJlYWtwb2ludHMubGd9IHtcbiAgICBtaW4td2lkdGg6IDM2cmVtO1xuICB9XG5gO1xuXG5jb25zdCBjYXJkSGVhZGVyVmFyaWFudHMgPSB2YXJpYW50KHtcbiAgYmFzZToge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgfSxcbiAgdmFyaWFudHM6IHtcbiAgICBbUHJvZHVjdC5CYXNpY106IHtcbiAgICAgIGJvcmRlckJvdHRvbVdpZHRoOiAxLFxuICAgICAgYm9yZGVyQm90dG9tU3R5bGU6ICdzb2xpZCcsXG4gICAgICBib3JkZXJCb3R0b21Db2xvcjogdGhlbWUuY29sb3JzWyduYXZ5LTIwMCddLFxuICAgICAgY29sb3I6ICduYXZ5LTUwMCcsXG4gICAgfSxcbiAgICBbUHJvZHVjdC5FbnRlcnByaXNlXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LlNpbHZlcl06IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLnBhbGVZZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Hb2xkXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuUHJvXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuVGVhbXNdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kLFxuICAgIH0sXG4gIH0sXG59KTtcblxuY29uc3QgQ2FyZEhlYWRlciA9IHN0eWxlZChGbGV4Qm94KShjYXJkSGVhZGVyVmFyaWFudHMpO1xuXG5jb25zdCBnZXRCYWRnZVRleHQgPSAocHJvZHVjdDogUHJvZHVjdCk6IHN0cmluZyB8IG51bGwgPT4ge1xuICBzd2l0Y2ggKHByb2R1Y3QpIHtcbiAgICBjYXNlIFByb2R1Y3QuR29sZDpcbiAgICAgIHJldHVybiAnQWR2YW5jZSB5b3VyIGNhcmVlcic7XG4gICAgY2FzZSBQcm9kdWN0LlNpbHZlcjpcbiAgICBjYXNlIFByb2R1Y3QuUHJvOlxuICAgICAgcmV0dXJuICdMZWFybiBhIHNraWxsJztcbiAgICBjYXNlIFByb2R1Y3QuVGVhbXM6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyKyc7XG4gICAgY2FzZSBQcm9kdWN0LkVudGVycHJpc2U6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyNSsnO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gbnVsbDtcbiAgfVxufTtcblxuY29uc3QgcmVuZGVyUHJvZHVjdERlc2NyaXB0aW9uID0gKHByb2R1Y3Q6IFByb2R1Y3QpID0+IHtcbiAgY29uc3QgcHJvZHVjdEZlYXR1cmVzID0gKFxuICAgIDxUZXh0IG1heFdpZHRoPXt7IG1kOiAnMjM1cHgnIH19IHRleHRBbGlnbj1cImNlbnRlclwiPlxuICAgICAge2dldFByb2R1Y3REZXNjcmlwdGlvbihwcm9kdWN0KX1cbiAgICA8L1RleHQ+
|
|
32
|
+
})("width:100%;max-width:", pxRem(smSize), ";height:100%;display:grid;", theme.breakpoints.lg, "{min-width:36rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AAmCsD","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n  trackBusinessClick,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n  trackBusinessClick?: ({\n    target,\n    context,\n  }: {\n    target: string;\n    context: string;\n  }) => void;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n            trackBusinessClick={trackBusinessClick}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */"));
|
|
33
33
|
const cardHeaderVariants = variant({
|
|
34
34
|
base: {
|
|
35
35
|
backgroundColor: 'transparent'
|
|
@@ -64,7 +64,7 @@ const cardHeaderVariants = variant({
|
|
|
64
64
|
const CardHeader = /*#__PURE__*/_styled(FlexBox, {
|
|
65
65
|
target: "e3n4z5j0",
|
|
66
66
|
label: "CardHeader"
|
|
67
|
-
})(cardHeaderVariants, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QcmljaW5nU2VjdGlvbi9QcmljaW5nQ2FyZC9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkVtQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUHJpY2luZ1NlY3Rpb24vUHJpY2luZ0NhcmQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFkZ2UsIEJveCwgQ2FyZCwgRmxleEJveCwgVGV4dCB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0JztcbmltcG9ydCB7IENoZWNrZXJEZW5zZSB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXBhdHRlcm5zJztcbmltcG9ydCB7IGNzcywgcHhSZW0sIHRoZW1lLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHsgQ29uZGl0aW9uYWxDb2xvck1vZGUgfSBmcm9tICcuLi9Db25kaXRpb25hbENvbG9yTW9kZSc7XG5pbXBvcnQgeyBnZXRQcm9kdWN0RGVzY3JpcHRpb24sIFBsYW5zQnlUeXBlIH0gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7IFByb2R1Y3RDVEEgfSBmcm9tICcuLi9Qcm9kdWN0Q1RBJztcbmltcG9ydCB7IFByb2R1Y3QsIFByb2R1Y3REZXRhaWxzLCBVc2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgUHJpY2luZ0Ftb3VudCB9IGZyb20gJy4vUHJpY2luZ0Ftb3VudCc7XG5pbXBvcnQgeyBSZWNvbW1lbmRlZEJhZGdlIH0gZnJvbSAnLi9SZWNvbW1lbmRlZEJhZGdlJztcbmltcG9ydCB7IEFsbEN1cnJlbmN5IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBzbVNpemUgPSA3Mjg7XG5cbmNvbnN0IFN0eWxlZENhcmQgPSBzdHlsZWQoQ2FyZCkoXG4gIGNzcyh7XG4gICAgaGVpZ2h0OiAxLFxuICAgIGJvcmRlcldpZHRoOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6ICcxMDAlJyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgfSlcbik7XG5cbmNvbnN0IERpdmlkZXIgPSBzdHlsZWQoQ2hlY2tlckRlbnNlKShcbiAgY3NzKHtcbiAgICBoZWlnaHQ6ICcwLjFyZW0nLFxuICB9KVxuKTtcblxudHlwZSBTdHlsZWRMaXN0Um93UHJvcHMgPSB7XG4gIHNob3dSZWNvbW1lbmRlZEJhZGdlOiBib29sZWFuO1xufTtcblxuY29uc3QgU3R5bGVkTGlzdFJvdyA9IHN0eWxlZCgnbGknKTxTdHlsZWRMaXN0Um93UHJvcHM+YFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiAke3B4UmVtKHNtU2l6ZSl9O1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7dGhlbWUuYnJlYWtwb2ludHMubGd9IHtcbiAgICBtaW4td2lkdGg6IDM2cmVtO1xuICB9XG5gO1xuXG5jb25zdCBjYXJkSGVhZGVyVmFyaWFudHMgPSB2YXJpYW50KHtcbiAgYmFzZToge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgfSxcbiAgdmFyaWFudHM6IHtcbiAgICBbUHJvZHVjdC5CYXNpY106IHtcbiAgICAgIGJvcmRlckJvdHRvbVdpZHRoOiAxLFxuICAgICAgYm9yZGVyQm90dG9tU3R5bGU6ICdzb2xpZCcsXG4gICAgICBib3JkZXJCb3R0b21Db2xvcjogdGhlbWUuY29sb3JzWyduYXZ5LTIwMCddLFxuICAgICAgY29sb3I6ICduYXZ5LTUwMCcsXG4gICAgfSxcbiAgICBbUHJvZHVjdC5FbnRlcnByaXNlXToge1xuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbUNvbG9yOiB0aGVtZS5jb2xvcnNbJ25hdnktMjAwJ10sXG4gICAgICBjb2xvcjogJ25hdnktNTAwJyxcbiAgICB9LFxuICAgIFtQcm9kdWN0LlNpbHZlcl06IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUuY29sb3JzLnBhbGVZZWxsb3csXG4gICAgfSxcbiAgICBbUHJvZHVjdC5Hb2xkXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuUHJvXToge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS5jb2xvcnMueWVsbG93LFxuICAgIH0sXG4gICAgW1Byb2R1Y3QuVGVhbXNdOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLmNvbG9ycy5iYWNrZ3JvdW5kLFxuICAgIH0sXG4gIH0sXG59KTtcblxuY29uc3QgQ2FyZEhlYWRlciA9IHN0eWxlZChGbGV4Qm94KShjYXJkSGVhZGVyVmFyaWFudHMpO1xuXG5jb25zdCBnZXRCYWRnZVRleHQgPSAocHJvZHVjdDogUHJvZHVjdCk6IHN0cmluZyB8IG51bGwgPT4ge1xuICBzd2l0Y2ggKHByb2R1Y3QpIHtcbiAgICBjYXNlIFByb2R1Y3QuR29sZDpcbiAgICAgIHJldHVybiAnQWR2YW5jZSB5b3VyIGNhcmVlcic7XG4gICAgY2FzZSBQcm9kdWN0LlNpbHZlcjpcbiAgICBjYXNlIFByb2R1Y3QuUHJvOlxuICAgICAgcmV0dXJuICdMZWFybiBhIHNraWxsJztcbiAgICBjYXNlIFByb2R1Y3QuVGVhbXM6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyKyc7XG4gICAgY2FzZSBQcm9kdWN0LkVudGVycHJpc2U6XG4gICAgICByZXR1cm4gJ1JlY29tbWVuZGVkIGZvciAyNSsnO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gbnVsbDtcbiAgfVxufTtcblxuY29uc3QgcmVuZGVyUHJvZHVjdERlc2NyaXB0aW9uID0gKHByb2R1Y3Q6IFByb2R1Y3QpID0+IHtcbiAgY29uc3QgcHJvZHVjdEZlYXR1cmVzID0gKFxuICAgIDxUZXh0IG1heFdpZHRoPXt7IG1kOiAnMjM1cHgnIH19IHRleHRBbGlnbj1cImNlbnRlclwiPlxuICAgICAge2dldFByb2R1Y3REZXNjcmlwdGlvbihwcm9kdWN0KX1cbiAgICA8L1RleHQ+
|
|
67
|
+
})(cardHeaderVariants, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/PricingSection/PricingCard/index.tsx"],"names":[],"mappings":"AA6EmB","file":"../../../src/PricingSection/PricingCard/index.tsx","sourcesContent":["import { Badge, Box, Card, FlexBox, Text } from '@codecademy/gamut';\nimport { CheckerDense } from '@codecademy/gamut-patterns';\nimport { css, pxRem, theme, variant } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\n\nimport { ConditionalColorMode } from '../ConditionalColorMode';\nimport { getProductDescription, PlansByType } from '../config';\nimport { ProductCTA } from '../ProductCTA';\nimport { Product, ProductDetails, User } from '../types';\nimport { PricingAmount } from './PricingAmount';\nimport { RecommendedBadge } from './RecommendedBadge';\nimport { AllCurrency } from './types';\n\nexport const smSize = 728;\n\nconst StyledCard = styled(Card)(\n  css({\n    height: 1,\n    borderWidth: 0,\n    padding: 0,\n    width: '100%',\n    flexDirection: 'column',\n  })\n);\n\nconst Divider = styled(CheckerDense)(\n  css({\n    height: '0.1rem',\n  })\n);\n\ntype StyledListRowProps = {\n  showRecommendedBadge: boolean;\n};\n\nconst StyledListRow = styled('li')<StyledListRowProps>`\n  width: 100%;\n  max-width: ${pxRem(smSize)};\n  height: 100%;\n  display: grid;\n  ${theme.breakpoints.lg} {\n    min-width: 36rem;\n  }\n`;\n\nconst cardHeaderVariants = variant({\n  base: {\n    backgroundColor: 'transparent',\n  },\n  variants: {\n    [Product.Basic]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Enterprise]: {\n      borderBottomWidth: 1,\n      borderBottomStyle: 'solid',\n      borderBottomColor: theme.colors['navy-200'],\n      color: 'navy-500',\n    },\n    [Product.Silver]: {\n      backgroundColor: theme.colors.paleYellow,\n    },\n    [Product.Gold]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Pro]: {\n      backgroundColor: theme.colors.yellow,\n    },\n    [Product.Teams]: {\n      backgroundColor: theme.colors.background,\n    },\n  },\n});\n\nconst CardHeader = styled(FlexBox)(cardHeaderVariants);\n\nconst getBadgeText = (product: Product): string | null => {\n  switch (product) {\n    case Product.Gold:\n      return 'Advance your career';\n    case Product.Silver:\n    case Product.Pro:\n      return 'Learn a skill';\n    case Product.Teams:\n      return 'Recommended for 2+';\n    case Product.Enterprise:\n      return 'Recommended for 25+';\n    default:\n      return null;\n  }\n};\n\nconst renderProductDescription = (product: Product) => {\n  const productFeatures = (\n    <Text maxWidth={{ md: '235px' }} textAlign=\"center\">\n      {getProductDescription(product)}\n    </Text>\n  );\n\n  return (\n    <FlexBox mt={8} alignItems=\"center\" flexDirection=\"column\">\n      {productFeatures}\n    </FlexBox>\n  );\n};\n\nexport const PricingCard = ({\n  product,\n  productDetails,\n  currency,\n  plansByType,\n  isUserInIndia,\n  user,\n  trackBusinessClick,\n}: {\n  product: Product;\n  productDetails: ProductDetails;\n  currency: AllCurrency;\n  plansByType: PlansByType;\n  isUserInIndia: boolean;\n  user: User;\n  trackBusinessClick?: ({\n    target,\n    context,\n  }: {\n    target: string;\n    context: string;\n  }) => void;\n}) => {\n  const isGoldProduct = product === Product.Gold;\n  const isTeamsProduct = product === Product.Teams;\n\n  return (\n    <StyledListRow showRecommendedBadge={product === Product.Gold}>\n      <StyledCard display=\"flex\" shadow=\"patternLeft\">\n        {isGoldProduct && <RecommendedBadge />}\n        <ConditionalColorMode condition={isTeamsProduct}>\n          <CardHeader\n            variant={product}\n            py={8}\n            px={24}\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n          >\n            <Text as=\"h2\" fontSize={{ _: 22, xl: 26 }}>\n              {plansByType[product].monthly?.displayName ||\n                plansByType[product].annual?.displayName}\n            </Text>\n            {isGoldProduct && <Text screenreader>Recommended</Text>}\n            {getBadgeText(product) && (\n              <Badge variant=\"tertiary\" ml={12}>\n                {getBadgeText(product)}\n              </Badge>\n            )}\n          </CardHeader>\n        </ConditionalColorMode>\n\n        <Box px={24} pt={24}>\n          <FlexBox center alignItems=\"flex-start\">\n            {product === Product.Enterprise ? (\n              <FlexBox\n                column\n                alignItems=\"center\"\n                justifyContent=\"center\"\n                minHeight={134}\n              >\n                <Text color=\"text-secondary\" mb={8} textAlign=\"center\">\n                  Looking to train a larger team?\n                </Text>\n                <Text variant=\"title-lg\" textAlign=\"center\">\n                  Contact us for a custom quote\n                </Text>\n              </FlexBox>\n            ) : (\n              <PricingAmount\n                monthlyPrice={plansByType[product].monthly?.price}\n                price={productDetails.price}\n                product={product}\n                currency={currency}\n                isUserInIndia={isUserInIndia}\n              />\n            )}\n          </FlexBox>\n\n          <FlexBox column alignItems=\"center\">\n            <Divider mt={16} />\n            <FlexBox\n              flexDirection=\"column\"\n              my={12}\n              /**\n               * Previously we were arbitrarily sizing cards to a width that was\n               * \"too small\" for the content they contained. The actual affect this was\n               * having was shrinking this section down to 256px, so rather than size\n               * the card, I'm opting to size this particular container w/i.\n               * This allows the cards themselves to be more flexible and simply styled\n               * while still maintaining the \"proper size\" on smaller screens.\n               */\n              width={{ _: 'unset', md: pxRem(256) }}\n            >\n              {renderProductDescription(product)}\n            </FlexBox>\n          </FlexBox>\n        </Box>\n        <FlexBox mb={24} mt=\"auto\" column>\n          <ProductCTA\n            user={user}\n            productDetails={productDetails}\n            product={product}\n            trackBusinessClick={trackBusinessClick}\n          />\n        </FlexBox>\n      </StyledCard>\n    </StyledListRow>\n  );\n};\n"]} */");
|
|
68
68
|
const getBadgeText = product => {
|
|
69
69
|
switch (product) {
|
|
70
70
|
case Product.Gold:
|
|
@@ -101,7 +101,8 @@ export const PricingCard = ({
|
|
|
101
101
|
currency,
|
|
102
102
|
plansByType,
|
|
103
103
|
isUserInIndia,
|
|
104
|
-
user
|
|
104
|
+
user,
|
|
105
|
+
trackBusinessClick
|
|
105
106
|
}) => {
|
|
106
107
|
const isGoldProduct = product === Product.Gold;
|
|
107
108
|
const isTeamsProduct = product === Product.Teams;
|
|
@@ -192,7 +193,8 @@ export const PricingCard = ({
|
|
|
192
193
|
children: /*#__PURE__*/_jsx(ProductCTA, {
|
|
193
194
|
user: user,
|
|
194
195
|
productDetails: productDetails,
|
|
195
|
-
product: product
|
|
196
|
+
product: product,
|
|
197
|
+
trackBusinessClick: trackBusinessClick
|
|
196
198
|
})
|
|
197
199
|
})]
|
|
198
200
|
})
|
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
import { Product, ProductDetails, User } from './types';
|
|
2
2
|
export declare const getCTATitle: (product: Product, isTrialPlan: boolean, isPlusUser?: boolean) => "" | "Request a demo" | "Try Teams for free" | "Purchase now" | "Sign up" | "Try Pro for free" | "Upgrade to Pro" | "Upgrade now" | "Try Plus for free" | "Your current plan";
|
|
3
|
-
export declare const ProductCTA: ({ product, productDetails, user, simple, }: {
|
|
3
|
+
export declare const ProductCTA: ({ product, productDetails, user, simple, trackBusinessClick, }: {
|
|
4
4
|
product: Product;
|
|
5
5
|
productDetails: ProductDetails;
|
|
6
6
|
user: User;
|
|
7
7
|
simple?: boolean;
|
|
8
|
+
trackBusinessClick?: ({ target, context, }: {
|
|
9
|
+
target: string;
|
|
10
|
+
context: string;
|
|
11
|
+
}) => void;
|
|
8
12
|
}) => import("react/jsx-runtime").JSX.Element | null;
|
|
@@ -57,11 +57,13 @@ export const ProductCTA = ({
|
|
|
57
57
|
product,
|
|
58
58
|
productDetails,
|
|
59
59
|
user,
|
|
60
|
-
simple
|
|
60
|
+
simple,
|
|
61
|
+
trackBusinessClick
|
|
61
62
|
}) => {
|
|
62
63
|
const userHasBasic = !user.anonymous && (!user.proSilver || !user.proGold);
|
|
63
64
|
const userHasSilver = user.proSilver;
|
|
64
65
|
const isTeams = product === Product.Teams;
|
|
66
|
+
const isEnterprise = product === Product.Enterprise;
|
|
65
67
|
const shouldHideCTA = () => {
|
|
66
68
|
if (isTeams) return false;
|
|
67
69
|
if ((userHasBasic || userHasSilver) && product === Product.Basic) {
|
|
@@ -88,6 +90,22 @@ export const ProductCTA = ({
|
|
|
88
90
|
product,
|
|
89
91
|
userHasSilver
|
|
90
92
|
}),
|
|
93
|
+
onClick: () => {
|
|
94
|
+
if (trackBusinessClick) {
|
|
95
|
+
if (isTeams) {
|
|
96
|
+
trackBusinessClick({
|
|
97
|
+
target: 'business_trial',
|
|
98
|
+
context: 'top_card'
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
if (isEnterprise) {
|
|
102
|
+
trackBusinessClick({
|
|
103
|
+
target: 'business_enterprise',
|
|
104
|
+
context: 'top_card'
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
},
|
|
91
109
|
children: /*#__PURE__*/_jsx(Text, {
|
|
92
110
|
as: "span",
|
|
93
111
|
children: getCTATitle(product, !!productDetails?.isTrialPlan, userHasSilver)
|
|
@@ -101,6 +119,14 @@ export const ProductCTA = ({
|
|
|
101
119
|
mt: 8,
|
|
102
120
|
children: /*#__PURE__*/_jsx(StrokeButton, {
|
|
103
121
|
href: "/business/checkout?plan_type=directpurchase",
|
|
122
|
+
onClick: () => {
|
|
123
|
+
if (trackBusinessClick) {
|
|
124
|
+
trackBusinessClick({
|
|
125
|
+
target: 'business_purchase',
|
|
126
|
+
context: 'top_card'
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
},
|
|
104
130
|
children: "Purchase now"
|
|
105
131
|
})
|
|
106
132
|
})]
|
|
@@ -6,6 +6,10 @@ interface ProductsProps {
|
|
|
6
6
|
user: User;
|
|
7
7
|
isUserInIndia: boolean;
|
|
8
8
|
currency: AllCurrency;
|
|
9
|
+
trackBusinessClick: ({ target, context, }: {
|
|
10
|
+
target: string;
|
|
11
|
+
context: string;
|
|
12
|
+
}) => void;
|
|
9
13
|
}
|
|
10
14
|
export declare const Products: React.FC<ProductsProps>;
|
|
11
15
|
export {};
|
|
@@ -7,7 +7,8 @@ export const Products = ({
|
|
|
7
7
|
plansByType,
|
|
8
8
|
user,
|
|
9
9
|
isUserInIndia,
|
|
10
|
-
currency
|
|
10
|
+
currency,
|
|
11
|
+
trackBusinessClick
|
|
11
12
|
}) => {
|
|
12
13
|
const productsLength = Object.keys(plansByType).length;
|
|
13
14
|
const renderCard = product => {
|
|
@@ -46,7 +47,8 @@ export const Products = ({
|
|
|
46
47
|
plansByType: plansByType,
|
|
47
48
|
isUserInIndia: isUserInIndia,
|
|
48
49
|
currency: currency,
|
|
49
|
-
user: user
|
|
50
|
+
user: user,
|
|
51
|
+
trackBusinessClick: trackBusinessClick
|
|
50
52
|
}, product);
|
|
51
53
|
case Product.Enterprise:
|
|
52
54
|
return /*#__PURE__*/_jsx(PricingCard, {
|
|
@@ -55,7 +57,8 @@ export const Products = ({
|
|
|
55
57
|
plansByType: plansByType,
|
|
56
58
|
isUserInIndia: isUserInIndia,
|
|
57
59
|
currency: currency,
|
|
58
|
-
user: user
|
|
60
|
+
user: user,
|
|
61
|
+
trackBusinessClick: trackBusinessClick
|
|
59
62
|
}, product);
|
|
60
63
|
default:
|
|
61
64
|
return null;
|
|
@@ -7,6 +7,10 @@ type PricingSectionProps = Omit<Partial<React.ComponentProps<typeof Background>>
|
|
|
7
7
|
user: User;
|
|
8
8
|
isUserInIndia: boolean;
|
|
9
9
|
currency: AllCurrency;
|
|
10
|
+
trackBusinessClick: ({ target, context, }: {
|
|
11
|
+
target: string;
|
|
12
|
+
context: string;
|
|
13
|
+
}) => void;
|
|
10
14
|
};
|
|
11
15
|
export declare const PricingSection: React.FC<PricingSectionProps>;
|
|
12
16
|
export {};
|
|
@@ -8,7 +8,8 @@ export const PricingSection = ({
|
|
|
8
8
|
title,
|
|
9
9
|
user,
|
|
10
10
|
isUserInIndia,
|
|
11
|
-
currency
|
|
11
|
+
currency,
|
|
12
|
+
trackBusinessClick
|
|
12
13
|
}) => {
|
|
13
14
|
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
14
15
|
children: [/*#__PURE__*/_jsx(Text, {
|
|
@@ -31,7 +32,8 @@ export const PricingSection = ({
|
|
|
31
32
|
plansByType: groupPlansByType(products),
|
|
32
33
|
user: user,
|
|
33
34
|
isUserInIndia: isUserInIndia,
|
|
34
|
-
currency: currency
|
|
35
|
+
currency: currency,
|
|
36
|
+
trackBusinessClick: trackBusinessClick
|
|
35
37
|
})
|
|
36
38
|
})]
|
|
37
39
|
})]
|
package/package.json
CHANGED