@stigg/react-sdk 5.28.4 → 5.29.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.
@@ -858,7 +858,12 @@ function isBulkTiers(tiers) {
858
858
  function isQuantityInFirstTier(tiers, quantity) {
859
859
  return (tiers == null ? void 0 : tiers[0].upTo) && quantity <= tiers[0].upTo;
860
860
  }
861
- function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex) {
861
+ function getTiersPerUnitQuantities(_ref4) {
862
+ var plan = _ref4.plan,
863
+ billingPeriod = _ref4.billingPeriod,
864
+ currentSubscription = _ref4.currentSubscription,
865
+ currentSubscriptionOverride = _ref4.currentSubscriptionOverride,
866
+ selectDefaultTierIndex = _ref4.selectDefaultTierIndex;
862
867
  var planTierPrices = plan.pricePoints.filter(function (price) {
863
868
  return price.billingPeriod === billingPeriod && price.isTieredPrice;
864
869
  });
@@ -884,6 +889,16 @@ function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, sel
884
889
  }
885
890
  }
886
891
 
892
+ if ((currentSubscriptionOverride == null ? void 0 : currentSubscriptionOverride.planId) === plan.id) {
893
+ var billableFeature = currentSubscriptionOverride.billableFeatures.find(function (billableFeature) {
894
+ return billableFeature.featureId === featureId;
895
+ });
896
+
897
+ if (billableFeature) {
898
+ quantity = billableFeature.quantity;
899
+ }
900
+ }
901
+
887
902
  var result = {};
888
903
  result[featureId] = quantity;
889
904
  return result;
@@ -899,7 +914,12 @@ var PriceTierComparison;
899
914
  PriceTierComparison[PriceTierComparison["Higher"] = 1] = "Higher";
900
915
  })(PriceTierComparison || (PriceTierComparison = {}));
901
916
 
902
- function compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription) {
917
+ function compareSelectedTierToCurrentTier(_ref5) {
918
+ var perUnitQuantityByFeature = _ref5.perUnitQuantityByFeature,
919
+ plan = _ref5.plan,
920
+ currentSubscription = _ref5.currentSubscription,
921
+ currentSubscriptionOverride = _ref5.currentSubscriptionOverride;
922
+
903
923
  if (!currentSubscription) {
904
924
  return PriceTierComparison.Equal;
905
925
  }
@@ -907,6 +927,15 @@ function compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubsc
907
927
  var currentTierPrice = currentSubscription.prices.find(function (price) {
908
928
  return price.pricingModel === BillingModel.PerUnit && price.tiersMode;
909
929
  });
930
+ var isCurrentPlanOverride = plan.id === (currentSubscriptionOverride == null ? void 0 : currentSubscriptionOverride.planId);
931
+
932
+ if (isCurrentPlanOverride) {
933
+ var _plan$pricePoints$fin;
934
+
935
+ currentTierPrice = (_plan$pricePoints$fin = plan.pricePoints.find(function (price) {
936
+ return price.pricingModel === BillingModel.PerUnit && price.tiersMode;
937
+ })) != null ? _plan$pricePoints$fin : currentTierPrice;
938
+ }
910
939
 
911
940
  if (!currentTierPrice) {
912
941
  return PriceTierComparison.Equal;
@@ -914,7 +943,20 @@ function compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubsc
914
943
 
915
944
  var _currentTierPrice$fea = currentTierPrice.feature,
916
945
  featureId = _currentTierPrice$fea.featureId,
917
- oldQuantity = _currentTierPrice$fea.unitQuantity;
946
+ unitQuantity = _currentTierPrice$fea.unitQuantity;
947
+ var oldQuantity = unitQuantity;
948
+
949
+ if (isCurrentPlanOverride) {
950
+ var _currentSubscriptionO;
951
+
952
+ var billableFeature = currentSubscriptionOverride == null ? void 0 : (_currentSubscriptionO = currentSubscriptionOverride.billableFeatures) == null ? void 0 : _currentSubscriptionO.find(function (billableFeature) {
953
+ return billableFeature.featureId === featureId;
954
+ });
955
+
956
+ if (billableFeature) {
957
+ oldQuantity = billableFeature.quantity;
958
+ }
959
+ }
918
960
 
919
961
  if (isNil(oldQuantity)) {
920
962
  return PriceTierComparison.Equal;
@@ -948,7 +990,7 @@ var LoadingIndicator = /*#__PURE__*/_styled(ClipLoader, process.env.NODE_ENV ===
948
990
  } : {
949
991
  name: "1a2afmv",
950
992
  styles: "margin-left:10px",
951
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAW4C","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
993
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAW4C","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, currentSubscriptionOverride, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier({\r\n                perUnitQuantityByFeature,\r\n                plan,\r\n                currentSubscription,\r\n                currentSubscriptionOverride,\r\n            });\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
952
994
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
953
995
  });
954
996
 
@@ -973,7 +1015,7 @@ var OfferingButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "pr
973
1015
  var theme = _ref5.theme,
974
1016
  $disabled = _ref5.$disabled;
975
1017
  return $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground;
976
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAcqC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */"));
1018
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAcqC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, currentSubscriptionOverride, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier({\r\n                perUnitQuantityByFeature,\r\n                plan,\r\n                currentSubscription,\r\n                currentSubscriptionOverride,\r\n            });\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */"));
977
1019
 
978
1020
  var ButtonText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "production" ? {
979
1021
  target: "e199qof94"
@@ -986,7 +1028,7 @@ var ButtonText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "prod
986
1028
  } : {
987
1029
  name: "h05omw",
988
1030
  styles: "margin:0;font-size:15px",
989
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAmCsC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
1031
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAmCsC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, currentSubscriptionOverride, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier({\r\n                perUnitQuantityByFeature,\r\n                plan,\r\n                currentSubscription,\r\n                currentSubscriptionOverride,\r\n            });\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
990
1032
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
991
1033
  });
992
1034
 
@@ -1001,7 +1043,7 @@ var ScheduledUpdateText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV
1001
1043
  } : {
1002
1044
  name: "1cnls12",
1003
1045
  styles: "min-height:87px",
1004
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAuC+C","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
1046
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAuC+C","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, currentSubscriptionOverride, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier({\r\n                perUnitQuantityByFeature,\r\n                plan,\r\n                currentSubscription,\r\n                currentSubscriptionOverride,\r\n            });\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
1005
1047
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
1006
1048
  });
1007
1049
 
@@ -1013,7 +1055,7 @@ var CancelScheduledUpdateButton = /*#__PURE__*/_styled("button", process.env.NOD
1013
1055
  })("background:none;border:none;padding:0;color:", function (_ref6) {
1014
1056
  var theme = _ref6.theme;
1015
1057
  return theme.stigg.palette.text.secondary;
1016
- }, ";text-decoration:underline;cursor:pointer;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AA0CkD","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */"));
1058
+ }, ";text-decoration:underline;cursor:pointer;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AA0CkD","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, currentSubscriptionOverride, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier({\r\n                perUnitQuantityByFeature,\r\n                plan,\r\n                currentSubscription,\r\n                currentSubscriptionOverride,\r\n            });\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */"));
1017
1059
 
1018
1060
  var TrialDaysLeft = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "production" ? {
1019
1061
  target: "e199qof91"
@@ -1026,7 +1068,7 @@ var TrialDaysLeft = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "p
1026
1068
  } : {
1027
1069
  name: "1etgg0o",
1028
1070
  styles: "margin-top:8px;margin-bottom:17px;min-height:20px",
1029
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAmDyC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
1071
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAmDyC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, currentSubscriptionOverride, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier({\r\n                perUnitQuantityByFeature,\r\n                plan,\r\n                currentSubscription,\r\n                currentSubscriptionOverride,\r\n            });\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */",
1030
1072
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
1031
1073
  });
1032
1074
 
@@ -1038,7 +1080,7 @@ var ButtonLayout = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "product
1038
1080
  })("display:flex;flex-direction:column;margin-top:4px;align-self:", function (_ref7) {
1039
1081
  var theme = _ref7.theme;
1040
1082
  return flexLayoutMapper(theme.stigg.layout.ctaAlignment);
1041
- }, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAwDgC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */"));
1083
+ }, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAwDgC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport { isFunction } from 'lodash';\r\nimport ClipLoader from 'react-spinners/ClipLoader';\r\nimport styled from '@emotion/styled/macro';\r\nimport { css, useTheme } from '@emotion/react';\r\nimport { SubscribeIntentionType } from './types';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from '../utils/priceTierUtils';\r\nconst LoadingIndicator = styled(ClipLoader) `\n  margin-left: 10px;\n`;\r\nconst OfferingButton = styled.button `\n  cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n  padding: 8px 12px;\n  background-color: ${({ theme }) => theme.stigg.palette.backgroundButton};\n  border: ${({ theme }) => `1px solid ${theme.stigg.palette.outlinedRestingBorder}`};\n  border-radius: 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 42px;\n  min-width: 120px;\n\n  ${({ $disabled }) => $disabled &&\r\n    css `\n      opacity: 0.5;\n    `}\n\n  &:hover {\n    background-color: ${({ theme, $disabled }) => $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground};\n  }\n`;\r\nconst ButtonText = styled(Typography) `\n  margin: 0;\n  font-size: 15px;\n`;\r\nconst ScheduledUpdateText = styled(Typography) `\n  min-height: 87px;\n`;\r\nconst CancelScheduledUpdateButton = styled.button `\n  background: none;\n  border: none;\n  padding: 0;\n  color: ${({ theme }) => theme.stigg.palette.text.secondary};\n\n  text-decoration: underline;\n  cursor: pointer;\n`;\r\nconst TrialDaysLeft = styled(Typography) `\n  margin-top: 8px;\n  margin-bottom: 17px;\n  min-height: 20px;\n`;\r\nconst ButtonLayout = styled.div `\n  display: flex;\n  flex-direction: column;\n  margin-top: 4px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, withTrialLeftRow, currentSubscription, currentSubscriptionOverride, perUnitQuantityByFeature, }) {\r\n    const theme = useTheme();\r\n    const [isLoading, setIsLoading] = useState(false);\r\n    const { currentPlan, custom, downgrade, startTrial, upgrade, startNew, switchToBillingPeriod, cancelScheduledUpdate, } = paywallLocale.planCTAButton;\r\n    const resolvedDowngrade = isFunction(downgrade) ? downgrade(plan) : downgrade;\r\n    const resolvedUpgrade = isFunction(upgrade) ? upgrade(plan) : upgrade;\r\n    const buttonProps = {\r\n        title: customer ? (plan.isLowerThanCurrentPlan ? resolvedDowngrade : resolvedUpgrade) : startNew,\r\n        disabled: false,\r\n        intentionType: plan.isLowerThanCurrentPlan\r\n            ? SubscribeIntentionType.DOWNGRADE_PLAN\r\n            : isCustomerOnTrial\r\n                ? SubscribeIntentionType.UPGRADE_TRIAL_TO_PAID\r\n                : SubscribeIntentionType.UPGRADE_PLAN,\r\n    };\r\n    const isCustomPrice = plan.pricingType === PricingType.Custom;\r\n    const { line1: scheduledUpdateText } = getSubscriptionScheduleUpdateTexts({\r\n        scheduledUpdate: plan.scheduledUpdate,\r\n        options: { withDate: true },\r\n    });\r\n    if (plan.isTriable && !plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        buttonProps.title = startTrial(plan);\r\n        buttonProps.intentionType = SubscribeIntentionType.START_TRIAL;\r\n    }\r\n    else if (plan.isCurrentCustomerPlan && !isCustomerOnTrial) {\r\n        const isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;\r\n        if (isSameBillingPeriod ||\r\n            (plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType))) {\r\n            const planComparison = compareSelectedTierToCurrentTier({\r\n                perUnitQuantityByFeature,\r\n                plan,\r\n                currentSubscription,\r\n                currentSubscriptionOverride,\r\n            });\r\n            switch (planComparison) {\r\n                case PriceTierComparison.Lower:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedDowngrade;\r\n                    break;\r\n                case PriceTierComparison.Higher:\r\n                    buttonProps.intentionType = SubscribeIntentionType.CHANGE_UNIT_QUANTITY;\r\n                    buttonProps.title = resolvedUpgrade;\r\n                    break;\r\n                default:\r\n                    buttonProps.title = currentPlan;\r\n                    buttonProps.disabled = true;\r\n                    break;\r\n            }\r\n        }\r\n        else {\r\n            buttonProps.title = switchToBillingPeriod(billingPeriod);\r\n            buttonProps.intentionType = SubscribeIntentionType.CHANGE_BILLING_PERIOD;\r\n        }\r\n    }\r\n    else if (isCustomPrice) {\r\n        buttonProps.title = typeof custom === 'function' ? custom({ plan, selectedBillingPeriod: billingPeriod }) : custom;\r\n        buttonProps.intentionType = SubscribeIntentionType.REQUEST_CUSTOM_PLAN_ACCESS;\r\n    }\r\n    if (isNextPlan && plan.scheduledUpdate) {\r\n        buttonProps.disabled = false;\r\n        buttonProps.title = cancelScheduledUpdate;\r\n        buttonProps.intentionType = SubscribeIntentionType.CANCEL_SCHEDULED_UPDATES;\r\n    }\r\n    const isDisabled = isLoading || buttonProps.disabled;\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(ButtonLayout, { className: \"stigg-paywall-plan-button-layout\" }, isNextPlan && scheduledUpdateText ? (React.createElement(ScheduledUpdateText, { color: \"secondary\", variant: \"body1\", className: \"stigg-paywall-schedule-update-text\" },\r\n            scheduledUpdateText,\r\n            ' ',\r\n            React.createElement(CancelScheduledUpdateButton, { color: \"secondary\", onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } }, buttonProps.title))) : (React.createElement(React.Fragment, null,\r\n            React.createElement(OfferingButton, { className: \"stigg-paywall-plan-button\", \"data-testid\": `paywall-card-cta-${plan.displayName}`, disabled: isDisabled, \"$disabled\": isDisabled, onClick: () => {\r\n                    setIsLoading(true);\r\n                    Promise.resolve(onPlanSelected(buttonProps.intentionType)).finally(() => setIsLoading(false));\r\n                } },\r\n                React.createElement(ButtonText, { className: \"stigg-paywall-plan-button-text\", variant: \"h6\", color: \"primary.main\" }, buttonProps.title),\r\n                isLoading && React.createElement(LoadingIndicator, { color: theme.stigg.palette.text.disabled, loading: true, size: 16 })),\r\n            !withTrialLeftRow ? (React.createElement(\"div\", { style: { height: '20px' } })) : (React.createElement(TrialDaysLeft, { className: \"stigg-trial-days-left-text\", variant: \"h6\", color: \"secondary\" }, plan.isCurrentCustomerPlan && plan.trialDaysLeft && (React.createElement(React.Fragment, null,\r\n                React.createElement(\"b\", null,\r\n                    plan.trialDaysLeft,\r\n                    \" days\"),\r\n                \" left on your free trial\")))))))));\r\n}\r\n//# sourceMappingURL=PlanOfferingButton.js.map"]} */"));
1042
1084
 
1043
1085
  function PlanOfferingButton(_ref8) {
1044
1086
  var isNextPlan = _ref8.isNextPlan,
@@ -1050,6 +1092,7 @@ function PlanOfferingButton(_ref8) {
1050
1092
  paywallLocale = _ref8.paywallLocale,
1051
1093
  withTrialLeftRow = _ref8.withTrialLeftRow,
1052
1094
  currentSubscription = _ref8.currentSubscription,
1095
+ currentSubscriptionOverride = _ref8.currentSubscriptionOverride,
1053
1096
  perUnitQuantityByFeature = _ref8.perUnitQuantityByFeature;
1054
1097
  var theme = useTheme();
1055
1098
 
@@ -1090,7 +1133,12 @@ function PlanOfferingButton(_ref8) {
1090
1133
  var isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;
1091
1134
 
1092
1135
  if (isSameBillingPeriod || plan.pricingType && [PricingType.Free, PricingType.Custom].includes(plan.pricingType)) {
1093
- var planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);
1136
+ var planComparison = compareSelectedTierToCurrentTier({
1137
+ perUnitQuantityByFeature: perUnitQuantityByFeature,
1138
+ plan: plan,
1139
+ currentSubscription: currentSubscription,
1140
+ currentSubscriptionOverride: currentSubscriptionOverride
1141
+ });
1094
1142
 
1095
1143
  switch (planComparison) {
1096
1144
  case PriceTierComparison.Lower:
@@ -1848,7 +1896,7 @@ var PlanOfferingContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV ===
1848
1896
  }, ";max-width:", function (_ref5) {
1849
1897
  var theme = _ref5.theme;
1850
1898
  return theme.stigg.layout.planMaxWidth;
1851
- }, ";flex-direction:column;align-items:flex-start;justify-content:flex-start;position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAayC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1899
+ }, ";flex-direction:column;align-items:flex-start;justify-content:flex-start;position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAayC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1852
1900
 
1853
1901
  var PlanHeader = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "production" ? {
1854
1902
  target: "eacdu8d7"
@@ -1861,7 +1909,7 @@ var PlanHeader = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "prod
1861
1909
  } : {
1862
1910
  name: "mpkj0c",
1863
1911
  styles: "padding-bottom:8px",
1864
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA2BsC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */",
1912
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA2BsC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */",
1865
1913
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
1866
1914
  });
1867
1915
 
@@ -1873,7 +1921,7 @@ var Divider = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production"
1873
1921
  })("height:2px;width:100%;background-color:", function (_ref6) {
1874
1922
  var theme = _ref6.theme;
1875
1923
  return theme.stigg.palette.outlinedBorder;
1876
- }, ";margin-bottom:40px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA8B2B","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1924
+ }, ";margin-bottom:40px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA8B2B","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1877
1925
 
1878
1926
  var PlanDescription = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "production" ? {
1879
1927
  target: "eacdu8d5"
@@ -1886,7 +1934,7 @@ var PlanDescription = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV ===
1886
1934
  }, ";min-height:", function (_ref8) {
1887
1935
  var theme = _ref8.theme;
1888
1936
  return theme.stigg.layout.descriptionMinHeight;
1889
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAoC2C","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1937
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAoC2C","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1890
1938
 
1891
1939
  var HighlightBadge = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
1892
1940
  target: "eacdu8d4"
@@ -1896,7 +1944,7 @@ var HighlightBadge = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produ
1896
1944
  })("background-color:", function (_ref9) {
1897
1945
  var theme = _ref9.theme;
1898
1946
  return theme.stigg.palette.primary;
1899
- }, ";border-radius:40px;position:absolute;top:-12px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAwCkC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1947
+ }, ";border-radius:40px;position:absolute;top:-12px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAwCkC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1900
1948
 
1901
1949
  var HighlightText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "production" ? {
1902
1950
  target: "eacdu8d3"
@@ -1909,7 +1957,7 @@ var HighlightText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "p
1909
1957
  } : {
1910
1958
  name: "a8c38r",
1911
1959
  styles: "margin:0;padding:2px 8px",
1912
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA8CyC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */",
1960
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA8CyC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */",
1913
1961
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
1914
1962
  });
1915
1963
 
@@ -1921,7 +1969,7 @@ var HeaderWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
1921
1969
  })("width:100%;display:flex;flex-direction:column;align-items:", function (_ref10) {
1922
1970
  var theme = _ref10.theme;
1923
1971
  return flexLayoutMapper(theme.stigg.layout.headerAlignment);
1924
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAkDiC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1972
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAkDiC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1925
1973
 
1926
1974
  var NextPlanTagContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
1927
1975
  target: "eacdu8d1"
@@ -1931,7 +1979,7 @@ var NextPlanTagContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV ===
1931
1979
  })("position:absolute;top:0;background-color:", function (_ref11) {
1932
1980
  var theme = _ref11.theme;
1933
1981
  return theme.stigg.palette.outlinedBorder;
1934
- }, ";border-radius:0px 0px 10px 10px;padding:3px 12px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAwDwC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1982
+ }, ";border-radius:0px 0px 10px 10px;padding:3px 12px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAwDwC","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1935
1983
 
1936
1984
  var StyledMiniSchedule = /*#__PURE__*/_styled(SvgMiniSchedule, process.env.NODE_ENV === "production" ? {
1937
1985
  target: "eacdu8d0"
@@ -1941,7 +1989,7 @@ var StyledMiniSchedule = /*#__PURE__*/_styled(SvgMiniSchedule, process.env.NODE_
1941
1989
  })("display:flex;height:100%;margin-right:4px;path{fill:", function (_ref12) {
1942
1990
  var theme = _ref12.theme;
1943
1991
  return theme.stigg.palette.text.primary;
1944
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA+DgD","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1992
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA+DgD","file":"PlanOffering.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\r\nimport styled from '@emotion/styled/macro';\r\nimport classNames from 'classnames';\r\nimport Grid from '@mui/material/Grid';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getTiersPerUnitQuantities } from '../utils/priceTierUtils';\r\nconst PlanOfferingButtonHeight = '66px';\r\nconst PlanOfferingContainer = styled.div `\n  position: relative;\n  background-color: ${({ theme, $isCurrentPlan }) => $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper};\n  border: ${({ theme, $isHighlighted }) => $isHighlighted ? `3px solid ${theme.stigg.palette.primary}` : `1px solid ${theme.stigg.palette.outlinedBorder}`};\n  border-radius: 10px;\n  padding: ${({ theme }) => theme.stigg.layout.planPadding};\n  display: flex;\n  min-width: ${({ theme }) => theme.stigg.layout.planMinWidth};\n  max-width: ${({ theme }) => theme.stigg.layout.planMaxWidth};\n  flex-direction: column;\n  align-items: flex-start;\n  justify-content: flex-start;\n  position: relative;\n`;\r\nconst PlanHeader = styled(Typography) `\n  padding-bottom: 8px;\n`;\r\nconst Divider = styled.div `\n  height: 2px;\n  width: 100%;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  margin-bottom: 40px;\n`;\r\nconst PlanDescription = styled(Typography) `\n  text-align: ${({ theme }) => theme.stigg.layout.descriptionAlignment};\n  min-height: ${({ theme }) => theme.stigg.layout.descriptionMinHeight};\n`;\r\nconst HighlightBadge = styled.div `\n  background-color: ${({ theme }) => theme.stigg.palette.primary};\n  border-radius: 40px;\n  position: absolute;\n  top: -12px;\n`;\r\nconst HighlightText = styled(Typography) `\n  margin: 0;\n  padding: 2px 8px;\n`;\r\nconst HeaderWrapper = styled.div `\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.headerAlignment)};\n`;\r\nconst NextPlanTagContainer = styled.div `\n  position: absolute;\n  top: 0;\n  background-color: ${({ theme }) => theme.stigg.palette.outlinedBorder};\n  border-radius: 0px 0px 10px 10px;\n  padding: 3px 12px;\n`;\r\nconst StyledMiniSchedule = styled(MiniSchedule) `\n  display: flex;\n  height: 100%;\n  margin-right: 4px;\n\n  path {\n    fill: ${({ theme }) => theme.stigg.palette.text.primary};\n  }\n`;\r\nfunction UpcomingChangeTag({ text = 'Next', iconsColor }) {\r\n    return (React.createElement(NextPlanTagContainer, null,\r\n        React.createElement(Grid, { display: \"flex\", alignItems: \"center\", gap: 1 },\r\n            React.createElement(StyledMiniSchedule, { \"$iconsColor\": iconsColor }),\r\n            React.createElement(Typography, { color: \"primary\", variant: \"body1\" }, text))));\r\n}\r\nexport function PlanOffering({ withUnitPriceRow, withTiersRow, withTrialLeftRow, customer, plan, billingPeriod, isHighlighted, currentSubscription, currentSubscriptionOverride, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, isCustomerInCustomPlan, selectDefaultTierIndex, }) {\r\n    const isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);\r\n    const planPrices = plan.pricePoints.filter((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const paywallCalculatedPrice = plan.paywallCalculatedPricePoints?.find((pricePoint) => pricePoint.billingPeriod === billingPeriod);\r\n    const showStartingAt = planPrices.length > 1 && !!paywallCalculatedPrice?.additionalChargesMayApply;\r\n    const showCTAButton = !isCustomerInCustomPlan || plan.pricingType === PricingType.Custom;\r\n    let planBadge = null;\r\n    if (isNextPlan) {\r\n        planBadge = React.createElement(UpcomingChangeTag, { text: \"Next plan\" });\r\n    }\r\n    else if (isHighlighted && paywallLocale.highlightChip) {\r\n        planBadge = (React.createElement(HighlightBadge, { className: \"stigg-highlight-badge\" },\r\n            React.createElement(HighlightText, { className: \"stigg-highlight-badge-text\", color: \"white\", bold: true }, paywallLocale.highlightChip)));\r\n    }\r\n    const [perUnitQuantityByFeature, setPerUnitQuantityByFeature] = useState(getTiersPerUnitQuantities({\r\n        plan,\r\n        billingPeriod,\r\n        currentSubscription,\r\n        currentSubscriptionOverride,\r\n        selectDefaultTierIndex,\r\n    }));\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const perUnitBillableFeatures = Object.keys(perUnitQuantityByFeature).map((featureId) => ({\r\n            featureId,\r\n            quantity: perUnitQuantityByFeature[featureId],\r\n        }));\r\n        return onPlanSelected(intentionType, perUnitBillableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames(`stigg-${plan.id}`, 'stigg-plan-offering-container', {\r\n            'stigg-current-plan': plan.isCurrentCustomerPlan,\r\n        }), \"$isHighlighted\": isHighlighted, \"$isCurrentPlan\": plan.isCurrentCustomerPlan },\r\n        planBadge,\r\n        React.createElement(HeaderWrapper, { className: \"stigg-header-wrapper\" },\r\n            React.createElement(PlanHeader, { className: \"stigg-plan-header\", variant: \"h3\" }, plan.displayName),\r\n            shouldShowDescriptionSection && (React.createElement(PlanDescription, { className: \"stigg-plan-description\", variant: \"h6\", color: \"secondary\" }, plan.description)),\r\n            React.createElement(PlanPrice, { showStartingAt: showStartingAt, withUnitPriceRow: withUnitPriceRow, withStartingAtRow: withStartingAtRow, withTiersRow: withTiersRow, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice, setPerUnitQuantityByFeature: setPerUnitQuantityByFeature, perUnitQuantityByFeature: perUnitQuantityByFeature }),\r\n            showCTAButton ? (React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, currentSubscriptionOverride: currentSubscriptionOverride, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, withTrialLeftRow: withTrialLeftRow, perUnitQuantityByFeature: perUnitQuantityByFeature })) : (React.createElement(\"div\", { style: { height: PlanOfferingButtonHeight } })),\r\n            React.createElement(Divider, { className: \"stigg-plan-header-divider\" })),\r\n        React.createElement(PlanEntitlements, { plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale })));\r\n}\r\n//# sourceMappingURL=PlanOffering.js.map"]} */"));
1945
1993
 
1946
1994
  function UpcomingChangeTag(_ref13) {
1947
1995
  var _ref13$text = _ref13.text,
@@ -1970,6 +2018,7 @@ function PlanOffering(_ref14) {
1970
2018
  billingPeriod = _ref14.billingPeriod,
1971
2019
  isHighlighted = _ref14.isHighlighted,
1972
2020
  currentSubscription = _ref14.currentSubscription,
2021
+ currentSubscriptionOverride = _ref14.currentSubscriptionOverride,
1973
2022
  shouldShowDescriptionSection = _ref14.shouldShowDescriptionSection,
1974
2023
  hasMonthlyPrice = _ref14.hasMonthlyPrice,
1975
2024
  hasAnnuallyPrice = _ref14.hasAnnuallyPrice,
@@ -2005,7 +2054,13 @@ function PlanOffering(_ref14) {
2005
2054
  }, paywallLocale.highlightChip));
2006
2055
  }
2007
2056
 
2008
- var _useState = useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex)),
2057
+ var _useState = useState(getTiersPerUnitQuantities({
2058
+ plan: plan,
2059
+ billingPeriod: billingPeriod,
2060
+ currentSubscription: currentSubscription,
2061
+ currentSubscriptionOverride: currentSubscriptionOverride,
2062
+ selectDefaultTierIndex: selectDefaultTierIndex
2063
+ })),
2009
2064
  perUnitQuantityByFeature = _useState[0],
2010
2065
  setPerUnitQuantityByFeature = _useState[1];
2011
2066
 
@@ -2052,6 +2107,7 @@ function PlanOffering(_ref14) {
2052
2107
  customer: customer,
2053
2108
  plan: plan,
2054
2109
  currentSubscription: currentSubscription,
2110
+ currentSubscriptionOverride: currentSubscriptionOverride,
2055
2111
  billingPeriod: billingPeriod,
2056
2112
  isCustomerOnTrial: isCustomerOnTrial,
2057
2113
  onPlanSelected: onPlanButtonClick,
@@ -2318,7 +2374,7 @@ var PaywallPlansContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV ===
2318
2374
  }, ";display:flex;align-items:stretch;justify-content:center;flex-wrap:wrap;padding:10px 0;gap:", function (_ref2) {
2319
2375
  var theme = _ref2.theme;
2320
2376
  return theme.stigg.layout.planMargin;
2321
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVl5QyIsImZpbGUiOiJQYXl3YWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpbGxpbmdQZXJpb2QsIFByaWNpbmdUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgUGxhbk9mZmVyaW5nIH0gZnJvbSAnLi9QbGFuT2ZmZXJpbmcnO1xyXG5pbXBvcnQgeyBCaWxsaW5nUGVyaW9kUGlja2VyIH0gZnJvbSAnLi9CaWxsaW5nUGVyaW9kUGlja2VyJztcclxuaW1wb3J0IHsgY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZSB9IGZyb20gJy4uL3V0aWxzL2NhbGN1bGF0ZURpc2NvdW50UmF0ZSc7XHJcbmltcG9ydCB7IFBvd2VyZWRCeVN0aWdnIH0gZnJvbSAnLi4vY29tbW9uL1Bvd2VyZWRCeVN0aWdnJztcclxuaW1wb3J0IHsgdXNlU3RpZ2dDb250ZXh0IH0gZnJvbSAnLi4vLi4nO1xyXG5pbXBvcnQgeyBoYXNQcmljZVBvaW50c0ZvclBsYW5zIH0gZnJvbSAnLi91dGlscy9oYXNQcmljZVBvaW50cyc7XHJcbmltcG9ydCB7IGdldFBsYW5zVG9EaXNwbGF5IH0gZnJvbSAnLi91dGlscy9nZXRQbGFuc1RvRGlzcGxheSc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMgfSBmcm9tICcuLi91dGlscy9wcmljZVRpZXJVdGlscyc7XHJcbmNvbnN0IFBheXdhbGxQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnRleHQucHJpbWFyeX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBwYWRkaW5nOiAxMHB4IDA7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG5gO1xyXG5jb25zdCBQYXl3YWxsQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5jb25zdCBQYXl3YWxsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5leHBvcnQgY29uc3QgUGF5d2FsbCA9ICh7IHBsYW5zLCBjdXN0b21lciwgY3VycmVudFN1YnNjcmlwdGlvbiwgaGlnaGxpZ2h0ZWRQbGFuSWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBzaG91bGRIaWRlUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleCwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdGlnZyB9ID0gdXNlU3RpZ2dDb250ZXh0KCk7XHJcbiAgICBjb25zdCBkaXNjb3VudFJhdGUgPSBjYWxjdWxhdGVQYXl3YWxsRGlzY291bnRSYXRlKHBsYW5zKTtcclxuICAgIGNvbnN0IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24gPSBwbGFucy5zb21lKChwbGFuKSA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgc2hvdWxkSGlkZVBsYW4pO1xyXG4gICAgY29uc3QgaGFuZGxlT25TdWJzY3JpYmUgPSB1c2VDYWxsYmFjaygocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4ge1xyXG4gICAgICAgIHJldHVybiBvblBsYW5TZWxlY3RlZCh7XHJcbiAgICAgICAgICAgIHBsYW4sXHJcbiAgICAgICAgICAgIGN1c3RvbWVyLFxyXG4gICAgICAgICAgICBzdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sXHJcbiAgICAgICAgICAgIGludGVudGlvblR5cGUsXHJcbiAgICAgICAgICAgIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgYmlsbGFibGVGZWF0dXJlcyxcclxuICAgICAgICB9KTtcclxuICAgIH0sIFtjdXN0b21lciwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBvblBsYW5TZWxlY3RlZF0pO1xyXG4gICAgY29uc3QgaXNDdXN0b21lckluQ3VzdG9tUGxhbiA9ICEhY3VycmVudFN1YnNjcmlwdGlvbiAmJiBjdXJyZW50U3Vic2NyaXB0aW9uLnBsYW4ucHJpY2luZ1R5cGUgPT09IFByaWNpbmdUeXBlLkN1c3RvbTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgY29uc3QgcGxhblByaWNlcyA9IHBsYW4ucHJpY2VQb2ludHMuZmlsdGVyKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2VzLmxlbmd0aCA+IDEgJiYgISFwYXl3YWxsQ2FsY3VsYXRlZFByaWNlPy5hZGRpdGlvbmFsQ2hhcmdlc01heUFwcGx5O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVW5pdFByaWNlUm93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBsb2NhbGUsIHBheXdhbGxMb2NhbGUsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVGllcnNSb3cgPSB1c2VNZW1vKCgpID0+IHtcclxuICAgICAgICByZXR1cm4gKCFpc0N1c3RvbWVySW5DdXN0b21QbGFuICYmXHJcbiAgICAgICAgICAgIHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IHRpZXJzID0gZ2V0VGllcnNQZXJVbml0UXVhbnRpdGllcyhwbGFuLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24pO1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIE9iamVjdC52YWx1ZXModGllcnMpLmxlbmd0aCA+IDA7XHJcbiAgICAgICAgICAgIH0pKTtcclxuICAgIH0sIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4sIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuLmlzQ3VycmVudEN1c3RvbWVyUGxhbiAmJiBwbGFuLnRyaWFsRGF5c0xlZnQ7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsTGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWxheW91dFwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZFBpY2tlciwgeyBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkOiBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHM6IGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBkaXNjb3VudFJhdGU6IGRpc2NvdW50UmF0ZSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtcGxhbnMtbGF5b3V0XCIgfSwgcGxhbnNUb1Nob3cubWFwKChwbGFuKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmcsIHsgd2l0aFVuaXRQcmljZVJvdzogd2l0aFVuaXRQcmljZVJvdywgd2l0aFRpZXJzUm93OiB3aXRoVGllcnNSb3csIHdpdGhUcmlhbExlZnRSb3c6IHdpdGhUcmlhbExlZnRSb3csIGtleTogcGxhbi5pZCwgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbjogc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIHBsYW46IHBsYW4sIHdpdGhTdGFydGluZ0F0Um93OiB3aXRoU3RhcnRpbmdBdFJvdywgY3VycmVudFN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbiwgYmlsbGluZ1BlcmlvZDogc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBpc0hpZ2hsaWdodGVkOiBwbGFuLmlkID09PSBoaWdobGlnaHRlZFBsYW5JZCwgaXNDdXN0b21lck9uVHJpYWw6IGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZDogKGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IGhhbmRsZU9uU3Vic2NyaWJlKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpLCBwYXl3YWxsTG9jYWxlOiBwYXl3YWxsTG9jYWxlLCBsb2NhbGU6IGxvY2FsZSwgY3VzdG9tZXI6IGN1c3RvbWVyLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuOiBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBzZWxlY3REZWZhdWx0VGllckluZGV4OiBzZWxlY3REZWZhdWx0VGllckluZGV4IH0pKSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBvd2VyZWRCeVN0aWdnLCB7IHNvdXJjZTogXCJwYXl3YWxsXCIsIGFsaWduOiBcImVuZFwiLCBzdHlsZTogeyBtYXJnaW5Ub3A6IDE2IH0sIHNob3dXYXRlcm1hcms6IHN0aWdnLmlzV2lkZ2V0V2F0ZXJtYXJrRW5hYmxlZCB9KSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9UGF5d2FsbC5qcy5tYXAiXX0= */"));
2377
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVl5QyIsImZpbGUiOiJQYXl3YWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpbGxpbmdQZXJpb2QsIFByaWNpbmdUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgUGxhbk9mZmVyaW5nIH0gZnJvbSAnLi9QbGFuT2ZmZXJpbmcnO1xyXG5pbXBvcnQgeyBCaWxsaW5nUGVyaW9kUGlja2VyIH0gZnJvbSAnLi9CaWxsaW5nUGVyaW9kUGlja2VyJztcclxuaW1wb3J0IHsgY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZSB9IGZyb20gJy4uL3V0aWxzL2NhbGN1bGF0ZURpc2NvdW50UmF0ZSc7XHJcbmltcG9ydCB7IFBvd2VyZWRCeVN0aWdnIH0gZnJvbSAnLi4vY29tbW9uL1Bvd2VyZWRCeVN0aWdnJztcclxuaW1wb3J0IHsgdXNlU3RpZ2dDb250ZXh0IH0gZnJvbSAnLi4vLi4nO1xyXG5pbXBvcnQgeyBoYXNQcmljZVBvaW50c0ZvclBsYW5zIH0gZnJvbSAnLi91dGlscy9oYXNQcmljZVBvaW50cyc7XHJcbmltcG9ydCB7IGdldFBsYW5zVG9EaXNwbGF5IH0gZnJvbSAnLi91dGlscy9nZXRQbGFuc1RvRGlzcGxheSc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMgfSBmcm9tICcuLi91dGlscy9wcmljZVRpZXJVdGlscyc7XHJcbmNvbnN0IFBheXdhbGxQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnRleHQucHJpbWFyeX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBwYWRkaW5nOiAxMHB4IDA7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG5gO1xyXG5jb25zdCBQYXl3YWxsQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5jb25zdCBQYXl3YWxsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5leHBvcnQgY29uc3QgUGF5d2FsbCA9ICh7IHBsYW5zLCBjdXN0b21lciwgY3VycmVudFN1YnNjcmlwdGlvbiwgaGlnaGxpZ2h0ZWRQbGFuSWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBzaG91bGRIaWRlUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleCwgY3VycmVudFN1YnNjcmlwdGlvbk92ZXJyaWRlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHN0aWdnIH0gPSB1c2VTdGlnZ0NvbnRleHQoKTtcclxuICAgIGNvbnN0IGRpc2NvdW50UmF0ZSA9IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUocGxhbnMpO1xyXG4gICAgY29uc3Qgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiA9IHBsYW5zLnNvbWUoKHBsYW4pID0+ICEhcGxhbi5kZXNjcmlwdGlvbik7XHJcbiAgICBjb25zdCBoYXNNb250aGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLk1vbnRobHkpO1xyXG4gICAgY29uc3QgaGFzQW5udWFsbHlQcmljZSA9IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMocGxhbnMsIEJpbGxpbmdQZXJpb2QuQW5udWFsbHkpO1xyXG4gICAgY29uc3QgcGxhbnNUb1Nob3cgPSBnZXRQbGFuc1RvRGlzcGxheShwbGFucywgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBzaG91bGRIaWRlUGxhbik7XHJcbiAgICBjb25zdCBoYW5kbGVPblN1YnNjcmliZSA9IHVzZUNhbGxiYWNrKChwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIG9uUGxhblNlbGVjdGVkKHtcclxuICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgY3VzdG9tZXIsXHJcbiAgICAgICAgICAgIHN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgaW50ZW50aW9uVHlwZSxcclxuICAgICAgICAgICAgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLFxyXG4gICAgICAgICAgICBiaWxsYWJsZUZlYXR1cmVzLFxyXG4gICAgICAgIH0pO1xyXG4gICAgfSwgW2N1c3RvbWVyLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24sIG9uUGxhblNlbGVjdGVkXSk7XHJcbiAgICBjb25zdCBpc0N1c3RvbWVySW5DdXN0b21QbGFuID0gISFjdXJyZW50U3Vic2NyaXB0aW9uICYmIGN1cnJlbnRTdWJzY3JpcHRpb24ucGxhbi5wcmljaW5nVHlwZSA9PT0gUHJpY2luZ1R5cGUuQ3VzdG9tO1xyXG4gICAgY29uc3Qgd2l0aFN0YXJ0aW5nQXRSb3cgPSB1c2VNZW1vKCgpID0+IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICBjb25zdCBwbGFuUHJpY2VzID0gcGxhbi5wcmljZVBvaW50cy5maWx0ZXIoKHByaWNlUG9pbnQpID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICBjb25zdCBwYXl3YWxsQ2FsY3VsYXRlZFByaWNlID0gcGxhbi5wYXl3YWxsQ2FsY3VsYXRlZFByaWNlUG9pbnRzPy5maW5kKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZXMubGVuZ3RoID4gMSAmJiAhIXBheXdhbGxDYWxjdWxhdGVkUHJpY2U/LmFkZGl0aW9uYWxDaGFyZ2VzTWF5QXBwbHk7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGxhbnNUb1Nob3ddKTtcclxuICAgIGNvbnN0IHdpdGhVbml0UHJpY2VSb3cgPSB1c2VNZW1vKCgpID0+IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICByZXR1cm4gISFnZXRQbGFuUHJpY2UocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSkudW5pdDtcclxuICAgIH0pLCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBoYXNNb250aGx5UHJpY2UsIGxvY2FsZSwgcGF5d2FsbExvY2FsZSwgcGxhbnNUb1Nob3ddKTtcclxuICAgIGNvbnN0IHdpdGhUaWVyc1JvdyA9IHVzZU1lbW8oKCkgPT4ge1xyXG4gICAgICAgIHJldHVybiAoIWlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4gJiZcclxuICAgICAgICAgICAgcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgdGllcnMgPSBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzKHtcclxuICAgICAgICAgICAgICAgICAgICBwbGFuLFxyXG4gICAgICAgICAgICAgICAgICAgIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50U3Vic2NyaXB0aW9uLFxyXG4gICAgICAgICAgICAgICAgICAgIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSxcclxuICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIE9iamVjdC52YWx1ZXModGllcnMpLmxlbmd0aCA+IDA7XHJcbiAgICAgICAgICAgIH0pKTtcclxuICAgIH0sIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgcGxhbnNUb1Nob3ddKTtcclxuICAgIGNvbnN0IHdpdGhUcmlhbExlZnRSb3cgPSBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW4uaXNDdXJyZW50Q3VzdG9tZXJQbGFuICYmIHBsYW4udHJpYWxEYXlzTGVmdDtcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBheXdhbGxDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtY29udGFpbmVyXCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBheXdhbGxMYXlvdXQsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtbGF5b3V0XCIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChCaWxsaW5nUGVyaW9kUGlja2VyLCB7IG9uQmlsbGluZ1BlcmlvZENoYW5nZWQ6IG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZDogc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBhdmFpbGFibGVCaWxsaW5nUGVyaW9kczogYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGRpc2NvdW50UmF0ZTogZGlzY291bnRSYXRlIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBheXdhbGxQbGFuc0NvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1wbGFucy1sYXlvdXRcIiB9LCBwbGFuc1RvU2hvdy5tYXAoKHBsYW4pID0+IChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZywgeyB3aXRoVW5pdFByaWNlUm93OiB3aXRoVW5pdFByaWNlUm93LCB3aXRoVGllcnNSb3c6IHdpdGhUaWVyc1Jvdywgd2l0aFRyaWFsTGVmdFJvdzogd2l0aFRyaWFsTGVmdFJvdywga2V5OiBwbGFuLmlkLCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uOiBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZTogaGFzQW5udWFsbHlQcmljZSwgcGxhbjogcGxhbiwgd2l0aFN0YXJ0aW5nQXRSb3c6IHdpdGhTdGFydGluZ0F0Um93LCBjdXJyZW50U3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLCBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGU6IGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgYmlsbGluZ1BlcmlvZDogc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBpc0hpZ2hsaWdodGVkOiBwbGFuLmlkID09PSBoaWdobGlnaHRlZFBsYW5JZCwgaXNDdXN0b21lck9uVHJpYWw6IGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZDogKGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IGhhbmRsZU9uU3Vic2NyaWJlKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpLCBwYXl3YWxsTG9jYWxlOiBwYXl3YWxsTG9jYWxlLCBsb2NhbGU6IGxvY2FsZSwgY3VzdG9tZXI6IGN1c3RvbWVyLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuOiBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBzZWxlY3REZWZhdWx0VGllckluZGV4OiBzZWxlY3REZWZhdWx0VGllckluZGV4IH0pKSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBvd2VyZWRCeVN0aWdnLCB7IHNvdXJjZTogXCJwYXl3YWxsXCIsIGFsaWduOiBcImVuZFwiLCBzdHlsZTogeyBtYXJnaW5Ub3A6IDE2IH0sIHNob3dXYXRlcm1hcms6IHN0aWdnLmlzV2lkZ2V0V2F0ZXJtYXJrRW5hYmxlZCB9KSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9UGF5d2FsbC5qcy5tYXAiXX0= */"));
2322
2378
 
2323
2379
  var PaywallContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
2324
2380
  target: "e19kubi81"
@@ -2331,7 +2387,7 @@ var PaywallContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pro
2331
2387
  } : {
2332
2388
  name: "1rdsyw8",
2333
2389
  styles: "display:flex;flex-direction:column;align-items:center;& *{box-sizing:border-box;}",
2334
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCb0MiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc3RpZ2cgfSA9IHVzZVN0aWdnQ29udGV4dCgpO1xyXG4gICAgY29uc3QgZGlzY291bnRSYXRlID0gY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZShwbGFucyk7XHJcbiAgICBjb25zdCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uID0gcGxhbnMuc29tZSgocGxhbikgPT4gISFwbGFuLmRlc2NyaXB0aW9uKTtcclxuICAgIGNvbnN0IGhhc01vbnRobHlQcmljZSA9IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMocGxhbnMsIEJpbGxpbmdQZXJpb2QuTW9udGhseSk7XHJcbiAgICBjb25zdCBoYXNBbm51YWxseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Bbm51YWxseSk7XHJcbiAgICBjb25zdCBwbGFuc1RvU2hvdyA9IGdldFBsYW5zVG9EaXNwbGF5KHBsYW5zLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHNob3VsZEhpZGVQbGFuKTtcclxuICAgIGNvbnN0IGhhbmRsZU9uU3Vic2NyaWJlID0gdXNlQ2FsbGJhY2soKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IHtcclxuICAgICAgICByZXR1cm4gb25QbGFuU2VsZWN0ZWQoe1xyXG4gICAgICAgICAgICBwbGFuLFxyXG4gICAgICAgICAgICBjdXN0b21lcixcclxuICAgICAgICAgICAgc3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLFxyXG4gICAgICAgICAgICBpbnRlbnRpb25UeXBlLFxyXG4gICAgICAgICAgICBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgIGJpbGxhYmxlRmVhdHVyZXMsXHJcbiAgICAgICAgfSk7XHJcbiAgICB9LCBbY3VzdG9tZXIsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgY3VycmVudFN1YnNjcmlwdGlvbiwgb25QbGFuU2VsZWN0ZWRdKTtcclxuICAgIGNvbnN0IGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4gPSAhIWN1cnJlbnRTdWJzY3JpcHRpb24gJiYgY3VycmVudFN1YnNjcmlwdGlvbi5wbGFuLnByaWNpbmdUeXBlID09PSBQcmljaW5nVHlwZS5DdXN0b207XHJcbiAgICBjb25zdCB3aXRoU3RhcnRpbmdBdFJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHBsYW5QcmljZXMgPSBwbGFuLnByaWNlUG9pbnRzLmZpbHRlcigocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIGNvbnN0IHBheXdhbGxDYWxjdWxhdGVkUHJpY2UgPSBwbGFuLnBheXdhbGxDYWxjdWxhdGVkUHJpY2VQb2ludHM/LmZpbmQoKHByaWNlUG9pbnQpID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlcy5sZW5ndGggPiAxICYmICEhcGF5d2FsbENhbGN1bGF0ZWRQcmljZT8uYWRkaXRpb25hbENoYXJnZXNNYXlBcHBseTtcclxuICAgIH0pLCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFVuaXRQcmljZVJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiAhIWdldFBsYW5QcmljZShwbGFuLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlKS51bml0O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGhhc01vbnRobHlQcmljZSwgbG9jYWxlLCBwYXl3YWxsTG9jYWxlLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRpZXJzUm93ID0gdXNlTWVtbygoKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICghaXNDdXN0b21lckluQ3VzdG9tUGxhbiAmJlxyXG4gICAgICAgICAgICBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBjb25zdCB0aWVycyA9IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uKTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRyaWFsTGVmdFJvdyA9IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhbi5pc0N1cnJlbnRDdXN0b21lclBsYW4gJiYgcGxhbi50cmlhbERheXNMZWZ0O1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbENvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbExheW91dCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1sYXlvdXRcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJpbGxpbmdQZXJpb2RQaWNrZXIsIHsgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZDogb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzOiBhdmFpbGFibGVCaWxsaW5nUGVyaW9kcywgZGlzY291bnRSYXRlOiBkaXNjb3VudFJhdGUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbFBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLXBsYW5zLWxheW91dFwiIH0sIHBsYW5zVG9TaG93Lm1hcCgocGxhbikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nLCB7IHdpdGhVbml0UHJpY2VSb3c6IHdpdGhVbml0UHJpY2VSb3csIHdpdGhUaWVyc1Jvdzogd2l0aFRpZXJzUm93LCB3aXRoVHJpYWxMZWZ0Um93OiB3aXRoVHJpYWxMZWZ0Um93LCBrZXk6IHBsYW4uaWQsIHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb246IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24sIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBwbGFuOiBwbGFuLCB3aXRoU3RhcnRpbmdBdFJvdzogd2l0aFN0YXJ0aW5nQXRSb3csIGN1cnJlbnRTdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2390
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCb0MiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdGlnZyB9ID0gdXNlU3RpZ2dDb250ZXh0KCk7XHJcbiAgICBjb25zdCBkaXNjb3VudFJhdGUgPSBjYWxjdWxhdGVQYXl3YWxsRGlzY291bnRSYXRlKHBsYW5zKTtcclxuICAgIGNvbnN0IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24gPSBwbGFucy5zb21lKChwbGFuKSA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgc2hvdWxkSGlkZVBsYW4pO1xyXG4gICAgY29uc3QgaGFuZGxlT25TdWJzY3JpYmUgPSB1c2VDYWxsYmFjaygocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4ge1xyXG4gICAgICAgIHJldHVybiBvblBsYW5TZWxlY3RlZCh7XHJcbiAgICAgICAgICAgIHBsYW4sXHJcbiAgICAgICAgICAgIGN1c3RvbWVyLFxyXG4gICAgICAgICAgICBzdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sXHJcbiAgICAgICAgICAgIGludGVudGlvblR5cGUsXHJcbiAgICAgICAgICAgIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgYmlsbGFibGVGZWF0dXJlcyxcclxuICAgICAgICB9KTtcclxuICAgIH0sIFtjdXN0b21lciwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBvblBsYW5TZWxlY3RlZF0pO1xyXG4gICAgY29uc3QgaXNDdXN0b21lckluQ3VzdG9tUGxhbiA9ICEhY3VycmVudFN1YnNjcmlwdGlvbiAmJiBjdXJyZW50U3Vic2NyaXB0aW9uLnBsYW4ucHJpY2luZ1R5cGUgPT09IFByaWNpbmdUeXBlLkN1c3RvbTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgY29uc3QgcGxhblByaWNlcyA9IHBsYW4ucHJpY2VQb2ludHMuZmlsdGVyKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2VzLmxlbmd0aCA+IDEgJiYgISFwYXl3YWxsQ2FsY3VsYXRlZFByaWNlPy5hZGRpdGlvbmFsQ2hhcmdlc01heUFwcGx5O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVW5pdFByaWNlUm93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBsb2NhbGUsIHBheXdhbGxMb2NhbGUsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVGllcnNSb3cgPSB1c2VNZW1vKCgpID0+IHtcclxuICAgICAgICByZXR1cm4gKCFpc0N1c3RvbWVySW5DdXN0b21QbGFuICYmXHJcbiAgICAgICAgICAgIHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IHRpZXJzID0gZ2V0VGllcnNQZXJVbml0UXVhbnRpdGllcyh7XHJcbiAgICAgICAgICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgICAgICAgICBiaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgICAgICAgICAgY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsXHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4sIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuLmlzQ3VycmVudEN1c3RvbWVyUGxhbiAmJiBwbGFuLnRyaWFsRGF5c0xlZnQ7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsTGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWxheW91dFwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZFBpY2tlciwgeyBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkOiBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHM6IGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBkaXNjb3VudFJhdGU6IGRpc2NvdW50UmF0ZSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtcGxhbnMtbGF5b3V0XCIgfSwgcGxhbnNUb1Nob3cubWFwKChwbGFuKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmcsIHsgd2l0aFVuaXRQcmljZVJvdzogd2l0aFVuaXRQcmljZVJvdywgd2l0aFRpZXJzUm93OiB3aXRoVGllcnNSb3csIHdpdGhUcmlhbExlZnRSb3c6IHdpdGhUcmlhbExlZnRSb3csIGtleTogcGxhbi5pZCwgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbjogc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIHBsYW46IHBsYW4sIHdpdGhTdGFydGluZ0F0Um93OiB3aXRoU3RhcnRpbmdBdFJvdywgY3VycmVudFN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbiwgY3VycmVudFN1YnNjcmlwdGlvbk92ZXJyaWRlOiBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2335
2391
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
2336
2392
  });
2337
2393
 
@@ -2346,7 +2402,7 @@ var PaywallLayout = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
2346
2402
  } : {
2347
2403
  name: "zigog8",
2348
2404
  styles: "display:flex;flex-direction:column;align-items:center",
2349
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCaUMiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc3RpZ2cgfSA9IHVzZVN0aWdnQ29udGV4dCgpO1xyXG4gICAgY29uc3QgZGlzY291bnRSYXRlID0gY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZShwbGFucyk7XHJcbiAgICBjb25zdCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uID0gcGxhbnMuc29tZSgocGxhbikgPT4gISFwbGFuLmRlc2NyaXB0aW9uKTtcclxuICAgIGNvbnN0IGhhc01vbnRobHlQcmljZSA9IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMocGxhbnMsIEJpbGxpbmdQZXJpb2QuTW9udGhseSk7XHJcbiAgICBjb25zdCBoYXNBbm51YWxseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Bbm51YWxseSk7XHJcbiAgICBjb25zdCBwbGFuc1RvU2hvdyA9IGdldFBsYW5zVG9EaXNwbGF5KHBsYW5zLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHNob3VsZEhpZGVQbGFuKTtcclxuICAgIGNvbnN0IGhhbmRsZU9uU3Vic2NyaWJlID0gdXNlQ2FsbGJhY2soKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IHtcclxuICAgICAgICByZXR1cm4gb25QbGFuU2VsZWN0ZWQoe1xyXG4gICAgICAgICAgICBwbGFuLFxyXG4gICAgICAgICAgICBjdXN0b21lcixcclxuICAgICAgICAgICAgc3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLFxyXG4gICAgICAgICAgICBpbnRlbnRpb25UeXBlLFxyXG4gICAgICAgICAgICBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgIGJpbGxhYmxlRmVhdHVyZXMsXHJcbiAgICAgICAgfSk7XHJcbiAgICB9LCBbY3VzdG9tZXIsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgY3VycmVudFN1YnNjcmlwdGlvbiwgb25QbGFuU2VsZWN0ZWRdKTtcclxuICAgIGNvbnN0IGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4gPSAhIWN1cnJlbnRTdWJzY3JpcHRpb24gJiYgY3VycmVudFN1YnNjcmlwdGlvbi5wbGFuLnByaWNpbmdUeXBlID09PSBQcmljaW5nVHlwZS5DdXN0b207XHJcbiAgICBjb25zdCB3aXRoU3RhcnRpbmdBdFJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHBsYW5QcmljZXMgPSBwbGFuLnByaWNlUG9pbnRzLmZpbHRlcigocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIGNvbnN0IHBheXdhbGxDYWxjdWxhdGVkUHJpY2UgPSBwbGFuLnBheXdhbGxDYWxjdWxhdGVkUHJpY2VQb2ludHM/LmZpbmQoKHByaWNlUG9pbnQpID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlcy5sZW5ndGggPiAxICYmICEhcGF5d2FsbENhbGN1bGF0ZWRQcmljZT8uYWRkaXRpb25hbENoYXJnZXNNYXlBcHBseTtcclxuICAgIH0pLCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFVuaXRQcmljZVJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiAhIWdldFBsYW5QcmljZShwbGFuLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlKS51bml0O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGhhc01vbnRobHlQcmljZSwgbG9jYWxlLCBwYXl3YWxsTG9jYWxlLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRpZXJzUm93ID0gdXNlTWVtbygoKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICghaXNDdXN0b21lckluQ3VzdG9tUGxhbiAmJlxyXG4gICAgICAgICAgICBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBjb25zdCB0aWVycyA9IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uKTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRyaWFsTGVmdFJvdyA9IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhbi5pc0N1cnJlbnRDdXN0b21lclBsYW4gJiYgcGxhbi50cmlhbERheXNMZWZ0O1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbENvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbExheW91dCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1sYXlvdXRcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJpbGxpbmdQZXJpb2RQaWNrZXIsIHsgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZDogb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzOiBhdmFpbGFibGVCaWxsaW5nUGVyaW9kcywgZGlzY291bnRSYXRlOiBkaXNjb3VudFJhdGUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbFBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLXBsYW5zLWxheW91dFwiIH0sIHBsYW5zVG9TaG93Lm1hcCgocGxhbikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nLCB7IHdpdGhVbml0UHJpY2VSb3c6IHdpdGhVbml0UHJpY2VSb3csIHdpdGhUaWVyc1Jvdzogd2l0aFRpZXJzUm93LCB3aXRoVHJpYWxMZWZ0Um93OiB3aXRoVHJpYWxMZWZ0Um93LCBrZXk6IHBsYW4uaWQsIHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb246IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24sIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBwbGFuOiBwbGFuLCB3aXRoU3RhcnRpbmdBdFJvdzogd2l0aFN0YXJ0aW5nQXRSb3csIGN1cnJlbnRTdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2405
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCaUMiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdGlnZyB9ID0gdXNlU3RpZ2dDb250ZXh0KCk7XHJcbiAgICBjb25zdCBkaXNjb3VudFJhdGUgPSBjYWxjdWxhdGVQYXl3YWxsRGlzY291bnRSYXRlKHBsYW5zKTtcclxuICAgIGNvbnN0IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24gPSBwbGFucy5zb21lKChwbGFuKSA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgc2hvdWxkSGlkZVBsYW4pO1xyXG4gICAgY29uc3QgaGFuZGxlT25TdWJzY3JpYmUgPSB1c2VDYWxsYmFjaygocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4ge1xyXG4gICAgICAgIHJldHVybiBvblBsYW5TZWxlY3RlZCh7XHJcbiAgICAgICAgICAgIHBsYW4sXHJcbiAgICAgICAgICAgIGN1c3RvbWVyLFxyXG4gICAgICAgICAgICBzdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sXHJcbiAgICAgICAgICAgIGludGVudGlvblR5cGUsXHJcbiAgICAgICAgICAgIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgYmlsbGFibGVGZWF0dXJlcyxcclxuICAgICAgICB9KTtcclxuICAgIH0sIFtjdXN0b21lciwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBvblBsYW5TZWxlY3RlZF0pO1xyXG4gICAgY29uc3QgaXNDdXN0b21lckluQ3VzdG9tUGxhbiA9ICEhY3VycmVudFN1YnNjcmlwdGlvbiAmJiBjdXJyZW50U3Vic2NyaXB0aW9uLnBsYW4ucHJpY2luZ1R5cGUgPT09IFByaWNpbmdUeXBlLkN1c3RvbTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgY29uc3QgcGxhblByaWNlcyA9IHBsYW4ucHJpY2VQb2ludHMuZmlsdGVyKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2VzLmxlbmd0aCA+IDEgJiYgISFwYXl3YWxsQ2FsY3VsYXRlZFByaWNlPy5hZGRpdGlvbmFsQ2hhcmdlc01heUFwcGx5O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVW5pdFByaWNlUm93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBsb2NhbGUsIHBheXdhbGxMb2NhbGUsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVGllcnNSb3cgPSB1c2VNZW1vKCgpID0+IHtcclxuICAgICAgICByZXR1cm4gKCFpc0N1c3RvbWVySW5DdXN0b21QbGFuICYmXHJcbiAgICAgICAgICAgIHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IHRpZXJzID0gZ2V0VGllcnNQZXJVbml0UXVhbnRpdGllcyh7XHJcbiAgICAgICAgICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgICAgICAgICBiaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgICAgICAgICAgY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsXHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4sIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuLmlzQ3VycmVudEN1c3RvbWVyUGxhbiAmJiBwbGFuLnRyaWFsRGF5c0xlZnQ7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsTGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWxheW91dFwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZFBpY2tlciwgeyBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkOiBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHM6IGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBkaXNjb3VudFJhdGU6IGRpc2NvdW50UmF0ZSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtcGxhbnMtbGF5b3V0XCIgfSwgcGxhbnNUb1Nob3cubWFwKChwbGFuKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmcsIHsgd2l0aFVuaXRQcmljZVJvdzogd2l0aFVuaXRQcmljZVJvdywgd2l0aFRpZXJzUm93OiB3aXRoVGllcnNSb3csIHdpdGhUcmlhbExlZnRSb3c6IHdpdGhUcmlhbExlZnRSb3csIGtleTogcGxhbi5pZCwgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbjogc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIHBsYW46IHBsYW4sIHdpdGhTdGFydGluZ0F0Um93OiB3aXRoU3RhcnRpbmdBdFJvdywgY3VycmVudFN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbiwgY3VycmVudFN1YnNjcmlwdGlvbk92ZXJyaWRlOiBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2350
2406
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
2351
2407
  });
2352
2408
 
@@ -2363,7 +2419,8 @@ var Paywall = function Paywall(_ref3) {
2363
2419
  paywallLocale = _ref3.paywallLocale,
2364
2420
  locale = _ref3.locale,
2365
2421
  shouldHidePlan = _ref3.shouldHidePlan,
2366
- selectDefaultTierIndex = _ref3.selectDefaultTierIndex;
2422
+ selectDefaultTierIndex = _ref3.selectDefaultTierIndex,
2423
+ currentSubscriptionOverride = _ref3.currentSubscriptionOverride;
2367
2424
 
2368
2425
  var _useStiggContext = useStiggContext(),
2369
2426
  stigg = _useStiggContext.stigg;
@@ -2406,10 +2463,15 @@ var Paywall = function Paywall(_ref3) {
2406
2463
  }, [selectedBillingPeriod, hasMonthlyPrice, locale, paywallLocale, plansToShow]);
2407
2464
  var withTiersRow = useMemo(function () {
2408
2465
  return !isCustomerInCustomPlan && plansToShow.some(function (plan) {
2409
- var tiers = getTiersPerUnitQuantities(plan, selectedBillingPeriod, currentSubscription);
2466
+ var tiers = getTiersPerUnitQuantities({
2467
+ plan: plan,
2468
+ billingPeriod: selectedBillingPeriod,
2469
+ currentSubscription: currentSubscription,
2470
+ currentSubscriptionOverride: currentSubscriptionOverride
2471
+ });
2410
2472
  return Object.values(tiers).length > 0;
2411
2473
  });
2412
- }, [selectedBillingPeriod, currentSubscription, isCustomerInCustomPlan, plansToShow]);
2474
+ }, [selectedBillingPeriod, currentSubscription, currentSubscriptionOverride, isCustomerInCustomPlan, plansToShow]);
2413
2475
  var withTrialLeftRow = plansToShow.some(function (plan) {
2414
2476
  return plan.isCurrentCustomerPlan && plan.trialDaysLeft;
2415
2477
  });
@@ -2436,6 +2498,7 @@ var Paywall = function Paywall(_ref3) {
2436
2498
  plan: plan,
2437
2499
  withStartingAtRow: withStartingAtRow,
2438
2500
  currentSubscription: currentSubscription,
2501
+ currentSubscriptionOverride: currentSubscriptionOverride,
2439
2502
  billingPeriod: selectedBillingPeriod,
2440
2503
  isHighlighted: plan.id === highlightedPlanId,
2441
2504
  isCustomerOnTrial: isCustomerOnTrial,
@@ -3467,7 +3530,7 @@ function getCustomerSubscriptionDetails(activeSubscriptions) {
3467
3530
  };
3468
3531
  }
3469
3532
 
3470
- function mapPaywallData(paywall, showOnlyEligiblePlans) {
3533
+ function mapPaywallData(paywall, showOnlyEligiblePlans, currentSubscriptionOverrideFn) {
3471
3534
  var _currentSubscription$;
3472
3535
 
3473
3536
  var _ref = paywall || {},
@@ -3484,6 +3547,9 @@ function mapPaywallData(paywall, showOnlyEligiblePlans) {
3484
3547
  isCustomerOnTrial = _getCustomerSubscript.isCustomerOnTrial,
3485
3548
  trialDaysLeft = _getCustomerSubscript.trialDaysLeft;
3486
3549
 
3550
+ var currentSubscriptionOverride = currentSubscriptionOverrideFn == null ? void 0 : currentSubscriptionOverrideFn({
3551
+ currentSubscription: currentSubscription
3552
+ });
3487
3553
  var scheduledUpdates = (currentSubscription == null ? void 0 : currentSubscription.scheduledUpdates) || [];
3488
3554
  var currentCustomerPlanBillingPeriod = currentSubscription == null ? void 0 : (_currentSubscription$ = currentSubscription.price) == null ? void 0 : _currentSubscription$.billingPeriod;
3489
3555
  var downgradeSchedule = scheduledUpdates.find(function (_ref2) {
@@ -3502,7 +3568,7 @@ function mapPaywallData(paywall, showOnlyEligiblePlans) {
3502
3568
  var eligibleForProductTrial = customer == null ? void 0 : (_customer$eligibleFor = customer.eligibleForTrial) == null ? void 0 : _customer$eligibleFor.find(function (productTrial) {
3503
3569
  return productTrial.productId === plan.product.id;
3504
3570
  });
3505
- var isCurrentCustomerPlan = plan.id === (currentPlan == null ? void 0 : currentPlan.id);
3571
+ var isCurrentCustomerPlan = currentSubscriptionOverride != null && currentSubscriptionOverride.planId ? (currentSubscriptionOverride == null ? void 0 : currentSubscriptionOverride.planId) === plan.id : plan.id === (currentPlan == null ? void 0 : currentPlan.id);
3506
3572
 
3507
3573
  var isNextPlan = function isNextPlan(currentBillingPeriod) {
3508
3574
  var _downgradeSchedule$ta;
@@ -3556,13 +3622,14 @@ function mapPaywallData(paywall, showOnlyEligiblePlans) {
3556
3622
  return {
3557
3623
  currentPlan: currentPlan,
3558
3624
  currentSubscription: currentSubscription,
3625
+ currentSubscriptionOverride: currentSubscriptionOverride,
3559
3626
  isCustomerOnTrial: isCustomerOnTrial,
3560
3627
  plans: paywallPlans,
3561
3628
  paywallConfiguration: paywallConfiguration
3562
3629
  };
3563
3630
  }
3564
3631
 
3565
- var version = "5.28.4";
3632
+ var version = "5.29.0";
3566
3633
  var name = "@stigg/react-sdk";
3567
3634
 
3568
3635
  var StiggContext = /*#__PURE__*/React__default.createContext(null);
@@ -3772,7 +3839,8 @@ function useLoadPaywallData(_ref) {
3772
3839
  resourceId = _ref.resourceId,
3773
3840
  showOnlyEligiblePlans = _ref.showOnlyEligiblePlans,
3774
3841
  billingCountryCode = _ref.billingCountryCode,
3775
- preferredBillingPeriod = _ref.preferredBillingPeriod;
3842
+ preferredBillingPeriod = _ref.preferredBillingPeriod,
3843
+ currentSubscriptionOverrideFn = _ref.currentSubscriptionOverrideFn;
3776
3844
 
3777
3845
  var _useStiggContext = useStiggContext(),
3778
3846
  stigg = _useStiggContext.stigg,
@@ -3850,7 +3918,7 @@ function useLoadPaywallData(_ref) {
3850
3918
 
3851
3919
  void loadPaywall();
3852
3920
  }, [stigg, productId, stigg.isCustomerLoaded, billingCountryCode, resourceId, preferredBillingPeriod]);
3853
- var paywallData = mapPaywallData(paywall, showOnlyEligiblePlans);
3921
+ var paywallData = mapPaywallData(paywall, showOnlyEligiblePlans, currentSubscriptionOverrideFn);
3854
3922
  return _extends({
3855
3923
  customer: (paywall == null ? void 0 : paywall.customer) || null,
3856
3924
  isLoading: isLoading,
@@ -4308,7 +4376,8 @@ var PaywallContainer$1 = function PaywallContainer(_ref) {
4308
4376
  onBillingPeriodChange = _ref.onBillingPeriodChange,
4309
4377
  billingCountryCode = _ref.billingCountryCode,
4310
4378
  shouldHidePlan = _ref.shouldHidePlan,
4311
- selectDefaultTierIndex = _ref.selectDefaultTierIndex;
4379
+ selectDefaultTierIndex = _ref.selectDefaultTierIndex,
4380
+ currentSubscriptionOverrideFn = _ref.currentSubscriptionOverride;
4312
4381
  var hasCustomerPortalContext = useCheckContextExists(CustomerPortalContext);
4313
4382
  var isCustomerPortalLoading = false;
4314
4383
 
@@ -4327,11 +4396,13 @@ var PaywallContainer$1 = function PaywallContainer(_ref) {
4327
4396
  resourceId: resourceId,
4328
4397
  showOnlyEligiblePlans: showOnlyEligiblePlans,
4329
4398
  billingCountryCode: billingCountryCode,
4330
- preferredBillingPeriod: preferredBillingPeriod
4399
+ preferredBillingPeriod: preferredBillingPeriod,
4400
+ currentSubscriptionOverrideFn: currentSubscriptionOverrideFn
4331
4401
  }),
4332
4402
  plans = _useLoadPaywallData.plans,
4333
4403
  customer = _useLoadPaywallData.customer,
4334
4404
  currentSubscription = _useLoadPaywallData.currentSubscription,
4405
+ currentSubscriptionOverride = _useLoadPaywallData.currentSubscriptionOverride,
4335
4406
  isCustomerOnTrial = _useLoadPaywallData.isCustomerOnTrial,
4336
4407
  isLoading = _useLoadPaywallData.isLoading,
4337
4408
  selectedBillingPeriod = _useLoadPaywallData.selectedBillingPeriod,
@@ -4354,6 +4425,7 @@ var PaywallContainer$1 = function PaywallContainer(_ref) {
4354
4425
  plans: plans,
4355
4426
  customer: customer,
4356
4427
  currentSubscription: currentSubscription,
4428
+ currentSubscriptionOverride: currentSubscriptionOverride,
4357
4429
  selectedBillingPeriod: selectedBillingPeriod,
4358
4430
  onBillingPeriodChanged: handlePeriodChange,
4359
4431
  availableBillingPeriods: availableBillingPeriods,