@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.
@@ -847,7 +847,12 @@ function isBulkTiers(tiers) {
847
847
  function isQuantityInFirstTier(tiers, quantity) {
848
848
  return (tiers == null ? void 0 : tiers[0].upTo) && quantity <= tiers[0].upTo;
849
849
  }
850
- function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex) {
850
+ function getTiersPerUnitQuantities(_ref4) {
851
+ var plan = _ref4.plan,
852
+ billingPeriod = _ref4.billingPeriod,
853
+ currentSubscription = _ref4.currentSubscription,
854
+ currentSubscriptionOverride = _ref4.currentSubscriptionOverride,
855
+ selectDefaultTierIndex = _ref4.selectDefaultTierIndex;
851
856
  var planTierPrices = plan.pricePoints.filter(function (price) {
852
857
  return price.billingPeriod === billingPeriod && price.isTieredPrice;
853
858
  });
@@ -873,6 +878,16 @@ function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, sel
873
878
  }
874
879
  }
875
880
 
881
+ if ((currentSubscriptionOverride == null ? void 0 : currentSubscriptionOverride.planId) === plan.id) {
882
+ var billableFeature = currentSubscriptionOverride.billableFeatures.find(function (billableFeature) {
883
+ return billableFeature.featureId === featureId;
884
+ });
885
+
886
+ if (billableFeature) {
887
+ quantity = billableFeature.quantity;
888
+ }
889
+ }
890
+
876
891
  var result = {};
877
892
  result[featureId] = quantity;
878
893
  return result;
@@ -888,7 +903,12 @@ var PriceTierComparison;
888
903
  PriceTierComparison[PriceTierComparison["Higher"] = 1] = "Higher";
889
904
  })(PriceTierComparison || (PriceTierComparison = {}));
890
905
 
891
- function compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription) {
906
+ function compareSelectedTierToCurrentTier(_ref5) {
907
+ var perUnitQuantityByFeature = _ref5.perUnitQuantityByFeature,
908
+ plan = _ref5.plan,
909
+ currentSubscription = _ref5.currentSubscription,
910
+ currentSubscriptionOverride = _ref5.currentSubscriptionOverride;
911
+
892
912
  if (!currentSubscription) {
893
913
  return PriceTierComparison.Equal;
894
914
  }
@@ -896,6 +916,15 @@ function compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubsc
896
916
  var currentTierPrice = currentSubscription.prices.find(function (price) {
897
917
  return price.pricingModel === Stigg.BillingModel.PerUnit && price.tiersMode;
898
918
  });
919
+ var isCurrentPlanOverride = plan.id === (currentSubscriptionOverride == null ? void 0 : currentSubscriptionOverride.planId);
920
+
921
+ if (isCurrentPlanOverride) {
922
+ var _plan$pricePoints$fin;
923
+
924
+ currentTierPrice = (_plan$pricePoints$fin = plan.pricePoints.find(function (price) {
925
+ return price.pricingModel === Stigg.BillingModel.PerUnit && price.tiersMode;
926
+ })) != null ? _plan$pricePoints$fin : currentTierPrice;
927
+ }
899
928
 
900
929
  if (!currentTierPrice) {
901
930
  return PriceTierComparison.Equal;
@@ -903,7 +932,20 @@ function compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubsc
903
932
 
904
933
  var _currentTierPrice$fea = currentTierPrice.feature,
905
934
  featureId = _currentTierPrice$fea.featureId,
906
- oldQuantity = _currentTierPrice$fea.unitQuantity;
935
+ unitQuantity = _currentTierPrice$fea.unitQuantity;
936
+ var oldQuantity = unitQuantity;
937
+
938
+ if (isCurrentPlanOverride) {
939
+ var _currentSubscriptionO;
940
+
941
+ var billableFeature = currentSubscriptionOverride == null ? void 0 : (_currentSubscriptionO = currentSubscriptionOverride.billableFeatures) == null ? void 0 : _currentSubscriptionO.find(function (billableFeature) {
942
+ return billableFeature.featureId === featureId;
943
+ });
944
+
945
+ if (billableFeature) {
946
+ oldQuantity = billableFeature.quantity;
947
+ }
948
+ }
907
949
 
908
950
  if (isNil(oldQuantity)) {
909
951
  return PriceTierComparison.Equal;
@@ -932,7 +974,7 @@ var LoadingIndicator = /*#__PURE__*/_styled(ClipLoader, {
932
974
  })( {
933
975
  name: "1a2afmv",
934
976
  styles: "margin-left:10px",
935
- 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"]} */",
977
+ 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"]} */",
936
978
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
937
979
  });
938
980
 
@@ -955,7 +997,7 @@ var OfferingButton = /*#__PURE__*/_styled("button", {
955
997
  var theme = _ref5.theme,
956
998
  $disabled = _ref5.$disabled;
957
999
  return $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground;
958
- }, ";}" + ( "/*# 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"]} */"));
1000
+ }, ";}" + ( "/*# 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"]} */"));
959
1001
 
960
1002
  var ButtonText = /*#__PURE__*/_styled(Typography, {
961
1003
  target: "e199qof94",
@@ -963,7 +1005,7 @@ var ButtonText = /*#__PURE__*/_styled(Typography, {
963
1005
  })( {
964
1006
  name: "h05omw",
965
1007
  styles: "margin:0;font-size:15px",
966
- 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"]} */",
1008
+ 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"]} */",
967
1009
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
968
1010
  });
969
1011
 
@@ -973,7 +1015,7 @@ var ScheduledUpdateText = /*#__PURE__*/_styled(Typography, {
973
1015
  })( {
974
1016
  name: "1cnls12",
975
1017
  styles: "min-height:87px",
976
- 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"]} */",
1018
+ 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"]} */",
977
1019
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
978
1020
  });
979
1021
 
@@ -983,7 +1025,7 @@ var CancelScheduledUpdateButton = /*#__PURE__*/_styled("button", {
983
1025
  })("background:none;border:none;padding:0;color:", function (_ref6) {
984
1026
  var theme = _ref6.theme;
985
1027
  return theme.stigg.palette.text.secondary;
986
- }, ";text-decoration:underline;cursor:pointer;" + ( "/*# 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"]} */"));
1028
+ }, ";text-decoration:underline;cursor:pointer;" + ( "/*# 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"]} */"));
987
1029
 
988
1030
  var TrialDaysLeft = /*#__PURE__*/_styled(Typography, {
989
1031
  target: "e199qof91",
@@ -991,7 +1033,7 @@ var TrialDaysLeft = /*#__PURE__*/_styled(Typography, {
991
1033
  })( {
992
1034
  name: "1etgg0o",
993
1035
  styles: "margin-top:8px;margin-bottom:17px;min-height:20px",
994
- 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"]} */",
1036
+ 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"]} */",
995
1037
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
996
1038
  });
997
1039
 
@@ -1001,7 +1043,7 @@ var ButtonLayout = /*#__PURE__*/_styled("div", {
1001
1043
  })("display:flex;flex-direction:column;margin-top:4px;align-self:", function (_ref7) {
1002
1044
  var theme = _ref7.theme;
1003
1045
  return flexLayoutMapper(theme.stigg.layout.ctaAlignment);
1004
- }, ";width:100%;" + ( "/*# 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"]} */"));
1046
+ }, ";width:100%;" + ( "/*# 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"]} */"));
1005
1047
 
1006
1048
  function PlanOfferingButton(_ref8) {
1007
1049
  var isNextPlan = _ref8.isNextPlan,
@@ -1013,6 +1055,7 @@ function PlanOfferingButton(_ref8) {
1013
1055
  paywallLocale = _ref8.paywallLocale,
1014
1056
  withTrialLeftRow = _ref8.withTrialLeftRow,
1015
1057
  currentSubscription = _ref8.currentSubscription,
1058
+ currentSubscriptionOverride = _ref8.currentSubscriptionOverride,
1016
1059
  perUnitQuantityByFeature = _ref8.perUnitQuantityByFeature;
1017
1060
  var theme = react.useTheme();
1018
1061
 
@@ -1053,7 +1096,12 @@ function PlanOfferingButton(_ref8) {
1053
1096
  var isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;
1054
1097
 
1055
1098
  if (isSameBillingPeriod || plan.pricingType && [Stigg.PricingType.Free, Stigg.PricingType.Custom].includes(plan.pricingType)) {
1056
- var planComparison = compareSelectedTierToCurrentTier(perUnitQuantityByFeature, currentSubscription);
1099
+ var planComparison = compareSelectedTierToCurrentTier({
1100
+ perUnitQuantityByFeature: perUnitQuantityByFeature,
1101
+ plan: plan,
1102
+ currentSubscription: currentSubscription,
1103
+ currentSubscriptionOverride: currentSubscriptionOverride
1104
+ });
1057
1105
 
1058
1106
  switch (planComparison) {
1059
1107
  case PriceTierComparison.Lower:
@@ -1758,7 +1806,7 @@ var PlanOfferingContainer = /*#__PURE__*/_styled("div", {
1758
1806
  }, ";max-width:", function (_ref5) {
1759
1807
  var theme = _ref5.theme;
1760
1808
  return theme.stigg.layout.planMaxWidth;
1761
- }, ";flex-direction:column;align-items:flex-start;justify-content:flex-start;position:relative;" + ( "/*# 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"]} */"));
1809
+ }, ";flex-direction:column;align-items:flex-start;justify-content:flex-start;position:relative;" + ( "/*# 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"]} */"));
1762
1810
 
1763
1811
  var PlanHeader = /*#__PURE__*/_styled(Typography, {
1764
1812
  target: "eacdu8d7",
@@ -1766,7 +1814,7 @@ var PlanHeader = /*#__PURE__*/_styled(Typography, {
1766
1814
  })( {
1767
1815
  name: "mpkj0c",
1768
1816
  styles: "padding-bottom:8px",
1769
- 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"]} */",
1817
+ 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"]} */",
1770
1818
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
1771
1819
  });
1772
1820
 
@@ -1776,7 +1824,7 @@ var Divider = /*#__PURE__*/_styled("div", {
1776
1824
  })("height:2px;width:100%;background-color:", function (_ref6) {
1777
1825
  var theme = _ref6.theme;
1778
1826
  return theme.stigg.palette.outlinedBorder;
1779
- }, ";margin-bottom:40px;" + ( "/*# 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"]} */"));
1827
+ }, ";margin-bottom:40px;" + ( "/*# 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"]} */"));
1780
1828
 
1781
1829
  var PlanDescription = /*#__PURE__*/_styled(Typography, {
1782
1830
  target: "eacdu8d5",
@@ -1787,7 +1835,7 @@ var PlanDescription = /*#__PURE__*/_styled(Typography, {
1787
1835
  }, ";min-height:", function (_ref8) {
1788
1836
  var theme = _ref8.theme;
1789
1837
  return theme.stigg.layout.descriptionMinHeight;
1790
- }, ";" + ( "/*# 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"]} */"));
1838
+ }, ";" + ( "/*# 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"]} */"));
1791
1839
 
1792
1840
  var HighlightBadge = /*#__PURE__*/_styled("div", {
1793
1841
  target: "eacdu8d4",
@@ -1795,7 +1843,7 @@ var HighlightBadge = /*#__PURE__*/_styled("div", {
1795
1843
  })("background-color:", function (_ref9) {
1796
1844
  var theme = _ref9.theme;
1797
1845
  return theme.stigg.palette.primary;
1798
- }, ";border-radius:40px;position:absolute;top:-12px;" + ( "/*# 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"]} */"));
1846
+ }, ";border-radius:40px;position:absolute;top:-12px;" + ( "/*# 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"]} */"));
1799
1847
 
1800
1848
  var HighlightText = /*#__PURE__*/_styled(Typography, {
1801
1849
  target: "eacdu8d3",
@@ -1803,7 +1851,7 @@ var HighlightText = /*#__PURE__*/_styled(Typography, {
1803
1851
  })( {
1804
1852
  name: "a8c38r",
1805
1853
  styles: "margin:0;padding:2px 8px",
1806
- 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"]} */",
1854
+ 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"]} */",
1807
1855
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
1808
1856
  });
1809
1857
 
@@ -1813,7 +1861,7 @@ var HeaderWrapper = /*#__PURE__*/_styled("div", {
1813
1861
  })("width:100%;display:flex;flex-direction:column;align-items:", function (_ref10) {
1814
1862
  var theme = _ref10.theme;
1815
1863
  return flexLayoutMapper(theme.stigg.layout.headerAlignment);
1816
- }, ";" + ( "/*# 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"]} */"));
1864
+ }, ";" + ( "/*# 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"]} */"));
1817
1865
 
1818
1866
  var NextPlanTagContainer = /*#__PURE__*/_styled("div", {
1819
1867
  target: "eacdu8d1",
@@ -1821,7 +1869,7 @@ var NextPlanTagContainer = /*#__PURE__*/_styled("div", {
1821
1869
  })("position:absolute;top:0;background-color:", function (_ref11) {
1822
1870
  var theme = _ref11.theme;
1823
1871
  return theme.stigg.palette.outlinedBorder;
1824
- }, ";border-radius:0px 0px 10px 10px;padding:3px 12px;" + ( "/*# 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"]} */"));
1872
+ }, ";border-radius:0px 0px 10px 10px;padding:3px 12px;" + ( "/*# 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"]} */"));
1825
1873
 
1826
1874
  var StyledMiniSchedule = /*#__PURE__*/_styled(SvgMiniSchedule, {
1827
1875
  target: "eacdu8d0",
@@ -1829,7 +1877,7 @@ var StyledMiniSchedule = /*#__PURE__*/_styled(SvgMiniSchedule, {
1829
1877
  })("display:flex;height:100%;margin-right:4px;path{fill:", function (_ref12) {
1830
1878
  var theme = _ref12.theme;
1831
1879
  return theme.stigg.palette.text.primary;
1832
- }, ";}" + ( "/*# 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"]} */"));
1880
+ }, ";}" + ( "/*# 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"]} */"));
1833
1881
 
1834
1882
  function UpcomingChangeTag(_ref13) {
1835
1883
  var _ref13$text = _ref13.text,
@@ -1858,6 +1906,7 @@ function PlanOffering(_ref14) {
1858
1906
  billingPeriod = _ref14.billingPeriod,
1859
1907
  isHighlighted = _ref14.isHighlighted,
1860
1908
  currentSubscription = _ref14.currentSubscription,
1909
+ currentSubscriptionOverride = _ref14.currentSubscriptionOverride,
1861
1910
  shouldShowDescriptionSection = _ref14.shouldShowDescriptionSection,
1862
1911
  hasMonthlyPrice = _ref14.hasMonthlyPrice,
1863
1912
  hasAnnuallyPrice = _ref14.hasAnnuallyPrice,
@@ -1893,7 +1942,13 @@ function PlanOffering(_ref14) {
1893
1942
  }, paywallLocale.highlightChip));
1894
1943
  }
1895
1944
 
1896
- var _useState = React.useState(getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex)),
1945
+ var _useState = React.useState(getTiersPerUnitQuantities({
1946
+ plan: plan,
1947
+ billingPeriod: billingPeriod,
1948
+ currentSubscription: currentSubscription,
1949
+ currentSubscriptionOverride: currentSubscriptionOverride,
1950
+ selectDefaultTierIndex: selectDefaultTierIndex
1951
+ })),
1897
1952
  perUnitQuantityByFeature = _useState[0],
1898
1953
  setPerUnitQuantityByFeature = _useState[1];
1899
1954
 
@@ -1940,6 +1995,7 @@ function PlanOffering(_ref14) {
1940
1995
  customer: customer,
1941
1996
  plan: plan,
1942
1997
  currentSubscription: currentSubscription,
1998
+ currentSubscriptionOverride: currentSubscriptionOverride,
1943
1999
  billingPeriod: billingPeriod,
1944
2000
  isCustomerOnTrial: isCustomerOnTrial,
1945
2001
  onPlanSelected: onPlanButtonClick,
@@ -2191,7 +2247,7 @@ var PaywallPlansContainer = /*#__PURE__*/_styled("div", {
2191
2247
  }, ";display:flex;align-items:stretch;justify-content:center;flex-wrap:wrap;padding:10px 0;gap:", function (_ref2) {
2192
2248
  var theme = _ref2.theme;
2193
2249
  return theme.stigg.layout.planMargin;
2194
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVl5QyIsImZpbGUiOiJQYXl3YWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpbGxpbmdQZXJpb2QsIFByaWNpbmdUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgUGxhbk9mZmVyaW5nIH0gZnJvbSAnLi9QbGFuT2ZmZXJpbmcnO1xyXG5pbXBvcnQgeyBCaWxsaW5nUGVyaW9kUGlja2VyIH0gZnJvbSAnLi9CaWxsaW5nUGVyaW9kUGlja2VyJztcclxuaW1wb3J0IHsgY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZSB9IGZyb20gJy4uL3V0aWxzL2NhbGN1bGF0ZURpc2NvdW50UmF0ZSc7XHJcbmltcG9ydCB7IFBvd2VyZWRCeVN0aWdnIH0gZnJvbSAnLi4vY29tbW9uL1Bvd2VyZWRCeVN0aWdnJztcclxuaW1wb3J0IHsgdXNlU3RpZ2dDb250ZXh0IH0gZnJvbSAnLi4vLi4nO1xyXG5pbXBvcnQgeyBoYXNQcmljZVBvaW50c0ZvclBsYW5zIH0gZnJvbSAnLi91dGlscy9oYXNQcmljZVBvaW50cyc7XHJcbmltcG9ydCB7IGdldFBsYW5zVG9EaXNwbGF5IH0gZnJvbSAnLi91dGlscy9nZXRQbGFuc1RvRGlzcGxheSc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMgfSBmcm9tICcuLi91dGlscy9wcmljZVRpZXJVdGlscyc7XHJcbmNvbnN0IFBheXdhbGxQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnRleHQucHJpbWFyeX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBwYWRkaW5nOiAxMHB4IDA7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG5gO1xyXG5jb25zdCBQYXl3YWxsQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5jb25zdCBQYXl3YWxsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5leHBvcnQgY29uc3QgUGF5d2FsbCA9ICh7IHBsYW5zLCBjdXN0b21lciwgY3VycmVudFN1YnNjcmlwdGlvbiwgaGlnaGxpZ2h0ZWRQbGFuSWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBzaG91bGRIaWRlUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleCwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdGlnZyB9ID0gdXNlU3RpZ2dDb250ZXh0KCk7XHJcbiAgICBjb25zdCBkaXNjb3VudFJhdGUgPSBjYWxjdWxhdGVQYXl3YWxsRGlzY291bnRSYXRlKHBsYW5zKTtcclxuICAgIGNvbnN0IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24gPSBwbGFucy5zb21lKChwbGFuKSA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgc2hvdWxkSGlkZVBsYW4pO1xyXG4gICAgY29uc3QgaGFuZGxlT25TdWJzY3JpYmUgPSB1c2VDYWxsYmFjaygocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4ge1xyXG4gICAgICAgIHJldHVybiBvblBsYW5TZWxlY3RlZCh7XHJcbiAgICAgICAgICAgIHBsYW4sXHJcbiAgICAgICAgICAgIGN1c3RvbWVyLFxyXG4gICAgICAgICAgICBzdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sXHJcbiAgICAgICAgICAgIGludGVudGlvblR5cGUsXHJcbiAgICAgICAgICAgIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgYmlsbGFibGVGZWF0dXJlcyxcclxuICAgICAgICB9KTtcclxuICAgIH0sIFtjdXN0b21lciwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBvblBsYW5TZWxlY3RlZF0pO1xyXG4gICAgY29uc3QgaXNDdXN0b21lckluQ3VzdG9tUGxhbiA9ICEhY3VycmVudFN1YnNjcmlwdGlvbiAmJiBjdXJyZW50U3Vic2NyaXB0aW9uLnBsYW4ucHJpY2luZ1R5cGUgPT09IFByaWNpbmdUeXBlLkN1c3RvbTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgY29uc3QgcGxhblByaWNlcyA9IHBsYW4ucHJpY2VQb2ludHMuZmlsdGVyKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2VzLmxlbmd0aCA+IDEgJiYgISFwYXl3YWxsQ2FsY3VsYXRlZFByaWNlPy5hZGRpdGlvbmFsQ2hhcmdlc01heUFwcGx5O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVW5pdFByaWNlUm93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBsb2NhbGUsIHBheXdhbGxMb2NhbGUsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVGllcnNSb3cgPSB1c2VNZW1vKCgpID0+IHtcclxuICAgICAgICByZXR1cm4gKCFpc0N1c3RvbWVySW5DdXN0b21QbGFuICYmXHJcbiAgICAgICAgICAgIHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IHRpZXJzID0gZ2V0VGllcnNQZXJVbml0UXVhbnRpdGllcyhwbGFuLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24pO1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIE9iamVjdC52YWx1ZXModGllcnMpLmxlbmd0aCA+IDA7XHJcbiAgICAgICAgICAgIH0pKTtcclxuICAgIH0sIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4sIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuLmlzQ3VycmVudEN1c3RvbWVyUGxhbiAmJiBwbGFuLnRyaWFsRGF5c0xlZnQ7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsTGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWxheW91dFwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZFBpY2tlciwgeyBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkOiBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHM6IGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBkaXNjb3VudFJhdGU6IGRpc2NvdW50UmF0ZSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtcGxhbnMtbGF5b3V0XCIgfSwgcGxhbnNUb1Nob3cubWFwKChwbGFuKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmcsIHsgd2l0aFVuaXRQcmljZVJvdzogd2l0aFVuaXRQcmljZVJvdywgd2l0aFRpZXJzUm93OiB3aXRoVGllcnNSb3csIHdpdGhUcmlhbExlZnRSb3c6IHdpdGhUcmlhbExlZnRSb3csIGtleTogcGxhbi5pZCwgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbjogc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIHBsYW46IHBsYW4sIHdpdGhTdGFydGluZ0F0Um93OiB3aXRoU3RhcnRpbmdBdFJvdywgY3VycmVudFN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbiwgYmlsbGluZ1BlcmlvZDogc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBpc0hpZ2hsaWdodGVkOiBwbGFuLmlkID09PSBoaWdobGlnaHRlZFBsYW5JZCwgaXNDdXN0b21lck9uVHJpYWw6IGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZDogKGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IGhhbmRsZU9uU3Vic2NyaWJlKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpLCBwYXl3YWxsTG9jYWxlOiBwYXl3YWxsTG9jYWxlLCBsb2NhbGU6IGxvY2FsZSwgY3VzdG9tZXI6IGN1c3RvbWVyLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuOiBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBzZWxlY3REZWZhdWx0VGllckluZGV4OiBzZWxlY3REZWZhdWx0VGllckluZGV4IH0pKSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBvd2VyZWRCeVN0aWdnLCB7IHNvdXJjZTogXCJwYXl3YWxsXCIsIGFsaWduOiBcImVuZFwiLCBzdHlsZTogeyBtYXJnaW5Ub3A6IDE2IH0sIHNob3dXYXRlcm1hcms6IHN0aWdnLmlzV2lkZ2V0V2F0ZXJtYXJrRW5hYmxlZCB9KSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9UGF5d2FsbC5qcy5tYXAiXX0= */"));
2250
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVl5QyIsImZpbGUiOiJQYXl3YWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpbGxpbmdQZXJpb2QsIFByaWNpbmdUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgUGxhbk9mZmVyaW5nIH0gZnJvbSAnLi9QbGFuT2ZmZXJpbmcnO1xyXG5pbXBvcnQgeyBCaWxsaW5nUGVyaW9kUGlja2VyIH0gZnJvbSAnLi9CaWxsaW5nUGVyaW9kUGlja2VyJztcclxuaW1wb3J0IHsgY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZSB9IGZyb20gJy4uL3V0aWxzL2NhbGN1bGF0ZURpc2NvdW50UmF0ZSc7XHJcbmltcG9ydCB7IFBvd2VyZWRCeVN0aWdnIH0gZnJvbSAnLi4vY29tbW9uL1Bvd2VyZWRCeVN0aWdnJztcclxuaW1wb3J0IHsgdXNlU3RpZ2dDb250ZXh0IH0gZnJvbSAnLi4vLi4nO1xyXG5pbXBvcnQgeyBoYXNQcmljZVBvaW50c0ZvclBsYW5zIH0gZnJvbSAnLi91dGlscy9oYXNQcmljZVBvaW50cyc7XHJcbmltcG9ydCB7IGdldFBsYW5zVG9EaXNwbGF5IH0gZnJvbSAnLi91dGlscy9nZXRQbGFuc1RvRGlzcGxheSc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMgfSBmcm9tICcuLi91dGlscy9wcmljZVRpZXJVdGlscyc7XHJcbmNvbnN0IFBheXdhbGxQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnRleHQucHJpbWFyeX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBwYWRkaW5nOiAxMHB4IDA7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG5gO1xyXG5jb25zdCBQYXl3YWxsQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5jb25zdCBQYXl3YWxsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5leHBvcnQgY29uc3QgUGF5d2FsbCA9ICh7IHBsYW5zLCBjdXN0b21lciwgY3VycmVudFN1YnNjcmlwdGlvbiwgaGlnaGxpZ2h0ZWRQbGFuSWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBzaG91bGRIaWRlUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleCwgY3VycmVudFN1YnNjcmlwdGlvbk92ZXJyaWRlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHN0aWdnIH0gPSB1c2VTdGlnZ0NvbnRleHQoKTtcclxuICAgIGNvbnN0IGRpc2NvdW50UmF0ZSA9IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUocGxhbnMpO1xyXG4gICAgY29uc3Qgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiA9IHBsYW5zLnNvbWUoKHBsYW4pID0+ICEhcGxhbi5kZXNjcmlwdGlvbik7XHJcbiAgICBjb25zdCBoYXNNb250aGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLk1vbnRobHkpO1xyXG4gICAgY29uc3QgaGFzQW5udWFsbHlQcmljZSA9IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMocGxhbnMsIEJpbGxpbmdQZXJpb2QuQW5udWFsbHkpO1xyXG4gICAgY29uc3QgcGxhbnNUb1Nob3cgPSBnZXRQbGFuc1RvRGlzcGxheShwbGFucywgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBzaG91bGRIaWRlUGxhbik7XHJcbiAgICBjb25zdCBoYW5kbGVPblN1YnNjcmliZSA9IHVzZUNhbGxiYWNrKChwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIG9uUGxhblNlbGVjdGVkKHtcclxuICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgY3VzdG9tZXIsXHJcbiAgICAgICAgICAgIHN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgaW50ZW50aW9uVHlwZSxcclxuICAgICAgICAgICAgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLFxyXG4gICAgICAgICAgICBiaWxsYWJsZUZlYXR1cmVzLFxyXG4gICAgICAgIH0pO1xyXG4gICAgfSwgW2N1c3RvbWVyLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24sIG9uUGxhblNlbGVjdGVkXSk7XHJcbiAgICBjb25zdCBpc0N1c3RvbWVySW5DdXN0b21QbGFuID0gISFjdXJyZW50U3Vic2NyaXB0aW9uICYmIGN1cnJlbnRTdWJzY3JpcHRpb24ucGxhbi5wcmljaW5nVHlwZSA9PT0gUHJpY2luZ1R5cGUuQ3VzdG9tO1xyXG4gICAgY29uc3Qgd2l0aFN0YXJ0aW5nQXRSb3cgPSB1c2VNZW1vKCgpID0+IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICBjb25zdCBwbGFuUHJpY2VzID0gcGxhbi5wcmljZVBvaW50cy5maWx0ZXIoKHByaWNlUG9pbnQpID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICBjb25zdCBwYXl3YWxsQ2FsY3VsYXRlZFByaWNlID0gcGxhbi5wYXl3YWxsQ2FsY3VsYXRlZFByaWNlUG9pbnRzPy5maW5kKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZXMubGVuZ3RoID4gMSAmJiAhIXBheXdhbGxDYWxjdWxhdGVkUHJpY2U/LmFkZGl0aW9uYWxDaGFyZ2VzTWF5QXBwbHk7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGxhbnNUb1Nob3ddKTtcclxuICAgIGNvbnN0IHdpdGhVbml0UHJpY2VSb3cgPSB1c2VNZW1vKCgpID0+IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICByZXR1cm4gISFnZXRQbGFuUHJpY2UocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSkudW5pdDtcclxuICAgIH0pLCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBoYXNNb250aGx5UHJpY2UsIGxvY2FsZSwgcGF5d2FsbExvY2FsZSwgcGxhbnNUb1Nob3ddKTtcclxuICAgIGNvbnN0IHdpdGhUaWVyc1JvdyA9IHVzZU1lbW8oKCkgPT4ge1xyXG4gICAgICAgIHJldHVybiAoIWlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4gJiZcclxuICAgICAgICAgICAgcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgdGllcnMgPSBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzKHtcclxuICAgICAgICAgICAgICAgICAgICBwbGFuLFxyXG4gICAgICAgICAgICAgICAgICAgIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50U3Vic2NyaXB0aW9uLFxyXG4gICAgICAgICAgICAgICAgICAgIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSxcclxuICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIE9iamVjdC52YWx1ZXModGllcnMpLmxlbmd0aCA+IDA7XHJcbiAgICAgICAgICAgIH0pKTtcclxuICAgIH0sIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgcGxhbnNUb1Nob3ddKTtcclxuICAgIGNvbnN0IHdpdGhUcmlhbExlZnRSb3cgPSBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW4uaXNDdXJyZW50Q3VzdG9tZXJQbGFuICYmIHBsYW4udHJpYWxEYXlzTGVmdDtcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBheXdhbGxDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtY29udGFpbmVyXCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBheXdhbGxMYXlvdXQsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtbGF5b3V0XCIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChCaWxsaW5nUGVyaW9kUGlja2VyLCB7IG9uQmlsbGluZ1BlcmlvZENoYW5nZWQ6IG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZDogc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBhdmFpbGFibGVCaWxsaW5nUGVyaW9kczogYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGRpc2NvdW50UmF0ZTogZGlzY291bnRSYXRlIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBheXdhbGxQbGFuc0NvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1wbGFucy1sYXlvdXRcIiB9LCBwbGFuc1RvU2hvdy5tYXAoKHBsYW4pID0+IChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZywgeyB3aXRoVW5pdFByaWNlUm93OiB3aXRoVW5pdFByaWNlUm93LCB3aXRoVGllcnNSb3c6IHdpdGhUaWVyc1Jvdywgd2l0aFRyaWFsTGVmdFJvdzogd2l0aFRyaWFsTGVmdFJvdywga2V5OiBwbGFuLmlkLCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uOiBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZTogaGFzQW5udWFsbHlQcmljZSwgcGxhbjogcGxhbiwgd2l0aFN0YXJ0aW5nQXRSb3c6IHdpdGhTdGFydGluZ0F0Um93LCBjdXJyZW50U3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLCBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGU6IGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgYmlsbGluZ1BlcmlvZDogc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBpc0hpZ2hsaWdodGVkOiBwbGFuLmlkID09PSBoaWdobGlnaHRlZFBsYW5JZCwgaXNDdXN0b21lck9uVHJpYWw6IGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZDogKGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IGhhbmRsZU9uU3Vic2NyaWJlKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpLCBwYXl3YWxsTG9jYWxlOiBwYXl3YWxsTG9jYWxlLCBsb2NhbGU6IGxvY2FsZSwgY3VzdG9tZXI6IGN1c3RvbWVyLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuOiBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBzZWxlY3REZWZhdWx0VGllckluZGV4OiBzZWxlY3REZWZhdWx0VGllckluZGV4IH0pKSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBvd2VyZWRCeVN0aWdnLCB7IHNvdXJjZTogXCJwYXl3YWxsXCIsIGFsaWduOiBcImVuZFwiLCBzdHlsZTogeyBtYXJnaW5Ub3A6IDE2IH0sIHNob3dXYXRlcm1hcms6IHN0aWdnLmlzV2lkZ2V0V2F0ZXJtYXJrRW5hYmxlZCB9KSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9UGF5d2FsbC5qcy5tYXAiXX0= */"));
2195
2251
 
2196
2252
  var PaywallContainer = /*#__PURE__*/_styled("div", {
2197
2253
  target: "e19kubi81",
@@ -2199,7 +2255,7 @@ var PaywallContainer = /*#__PURE__*/_styled("div", {
2199
2255
  })( {
2200
2256
  name: "1rdsyw8",
2201
2257
  styles: "display:flex;flex-direction:column;align-items:center;& *{box-sizing:border-box;}",
2202
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCb0MiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc3RpZ2cgfSA9IHVzZVN0aWdnQ29udGV4dCgpO1xyXG4gICAgY29uc3QgZGlzY291bnRSYXRlID0gY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZShwbGFucyk7XHJcbiAgICBjb25zdCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uID0gcGxhbnMuc29tZSgocGxhbikgPT4gISFwbGFuLmRlc2NyaXB0aW9uKTtcclxuICAgIGNvbnN0IGhhc01vbnRobHlQcmljZSA9IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMocGxhbnMsIEJpbGxpbmdQZXJpb2QuTW9udGhseSk7XHJcbiAgICBjb25zdCBoYXNBbm51YWxseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Bbm51YWxseSk7XHJcbiAgICBjb25zdCBwbGFuc1RvU2hvdyA9IGdldFBsYW5zVG9EaXNwbGF5KHBsYW5zLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHNob3VsZEhpZGVQbGFuKTtcclxuICAgIGNvbnN0IGhhbmRsZU9uU3Vic2NyaWJlID0gdXNlQ2FsbGJhY2soKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IHtcclxuICAgICAgICByZXR1cm4gb25QbGFuU2VsZWN0ZWQoe1xyXG4gICAgICAgICAgICBwbGFuLFxyXG4gICAgICAgICAgICBjdXN0b21lcixcclxuICAgICAgICAgICAgc3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLFxyXG4gICAgICAgICAgICBpbnRlbnRpb25UeXBlLFxyXG4gICAgICAgICAgICBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgIGJpbGxhYmxlRmVhdHVyZXMsXHJcbiAgICAgICAgfSk7XHJcbiAgICB9LCBbY3VzdG9tZXIsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgY3VycmVudFN1YnNjcmlwdGlvbiwgb25QbGFuU2VsZWN0ZWRdKTtcclxuICAgIGNvbnN0IGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4gPSAhIWN1cnJlbnRTdWJzY3JpcHRpb24gJiYgY3VycmVudFN1YnNjcmlwdGlvbi5wbGFuLnByaWNpbmdUeXBlID09PSBQcmljaW5nVHlwZS5DdXN0b207XHJcbiAgICBjb25zdCB3aXRoU3RhcnRpbmdBdFJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHBsYW5QcmljZXMgPSBwbGFuLnByaWNlUG9pbnRzLmZpbHRlcigocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIGNvbnN0IHBheXdhbGxDYWxjdWxhdGVkUHJpY2UgPSBwbGFuLnBheXdhbGxDYWxjdWxhdGVkUHJpY2VQb2ludHM/LmZpbmQoKHByaWNlUG9pbnQpID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlcy5sZW5ndGggPiAxICYmICEhcGF5d2FsbENhbGN1bGF0ZWRQcmljZT8uYWRkaXRpb25hbENoYXJnZXNNYXlBcHBseTtcclxuICAgIH0pLCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFVuaXRQcmljZVJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiAhIWdldFBsYW5QcmljZShwbGFuLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlKS51bml0O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGhhc01vbnRobHlQcmljZSwgbG9jYWxlLCBwYXl3YWxsTG9jYWxlLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRpZXJzUm93ID0gdXNlTWVtbygoKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICghaXNDdXN0b21lckluQ3VzdG9tUGxhbiAmJlxyXG4gICAgICAgICAgICBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBjb25zdCB0aWVycyA9IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uKTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRyaWFsTGVmdFJvdyA9IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhbi5pc0N1cnJlbnRDdXN0b21lclBsYW4gJiYgcGxhbi50cmlhbERheXNMZWZ0O1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbENvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbExheW91dCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1sYXlvdXRcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJpbGxpbmdQZXJpb2RQaWNrZXIsIHsgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZDogb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzOiBhdmFpbGFibGVCaWxsaW5nUGVyaW9kcywgZGlzY291bnRSYXRlOiBkaXNjb3VudFJhdGUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbFBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLXBsYW5zLWxheW91dFwiIH0sIHBsYW5zVG9TaG93Lm1hcCgocGxhbikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nLCB7IHdpdGhVbml0UHJpY2VSb3c6IHdpdGhVbml0UHJpY2VSb3csIHdpdGhUaWVyc1Jvdzogd2l0aFRpZXJzUm93LCB3aXRoVHJpYWxMZWZ0Um93OiB3aXRoVHJpYWxMZWZ0Um93LCBrZXk6IHBsYW4uaWQsIHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb246IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24sIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBwbGFuOiBwbGFuLCB3aXRoU3RhcnRpbmdBdFJvdzogd2l0aFN0YXJ0aW5nQXRSb3csIGN1cnJlbnRTdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2258
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCb0MiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdGlnZyB9ID0gdXNlU3RpZ2dDb250ZXh0KCk7XHJcbiAgICBjb25zdCBkaXNjb3VudFJhdGUgPSBjYWxjdWxhdGVQYXl3YWxsRGlzY291bnRSYXRlKHBsYW5zKTtcclxuICAgIGNvbnN0IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24gPSBwbGFucy5zb21lKChwbGFuKSA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgc2hvdWxkSGlkZVBsYW4pO1xyXG4gICAgY29uc3QgaGFuZGxlT25TdWJzY3JpYmUgPSB1c2VDYWxsYmFjaygocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4ge1xyXG4gICAgICAgIHJldHVybiBvblBsYW5TZWxlY3RlZCh7XHJcbiAgICAgICAgICAgIHBsYW4sXHJcbiAgICAgICAgICAgIGN1c3RvbWVyLFxyXG4gICAgICAgICAgICBzdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sXHJcbiAgICAgICAgICAgIGludGVudGlvblR5cGUsXHJcbiAgICAgICAgICAgIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgYmlsbGFibGVGZWF0dXJlcyxcclxuICAgICAgICB9KTtcclxuICAgIH0sIFtjdXN0b21lciwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBvblBsYW5TZWxlY3RlZF0pO1xyXG4gICAgY29uc3QgaXNDdXN0b21lckluQ3VzdG9tUGxhbiA9ICEhY3VycmVudFN1YnNjcmlwdGlvbiAmJiBjdXJyZW50U3Vic2NyaXB0aW9uLnBsYW4ucHJpY2luZ1R5cGUgPT09IFByaWNpbmdUeXBlLkN1c3RvbTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgY29uc3QgcGxhblByaWNlcyA9IHBsYW4ucHJpY2VQb2ludHMuZmlsdGVyKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2VzLmxlbmd0aCA+IDEgJiYgISFwYXl3YWxsQ2FsY3VsYXRlZFByaWNlPy5hZGRpdGlvbmFsQ2hhcmdlc01heUFwcGx5O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVW5pdFByaWNlUm93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBsb2NhbGUsIHBheXdhbGxMb2NhbGUsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVGllcnNSb3cgPSB1c2VNZW1vKCgpID0+IHtcclxuICAgICAgICByZXR1cm4gKCFpc0N1c3RvbWVySW5DdXN0b21QbGFuICYmXHJcbiAgICAgICAgICAgIHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IHRpZXJzID0gZ2V0VGllcnNQZXJVbml0UXVhbnRpdGllcyh7XHJcbiAgICAgICAgICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgICAgICAgICBiaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgICAgICAgICAgY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsXHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4sIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuLmlzQ3VycmVudEN1c3RvbWVyUGxhbiAmJiBwbGFuLnRyaWFsRGF5c0xlZnQ7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsTGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWxheW91dFwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZFBpY2tlciwgeyBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkOiBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHM6IGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBkaXNjb3VudFJhdGU6IGRpc2NvdW50UmF0ZSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtcGxhbnMtbGF5b3V0XCIgfSwgcGxhbnNUb1Nob3cubWFwKChwbGFuKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmcsIHsgd2l0aFVuaXRQcmljZVJvdzogd2l0aFVuaXRQcmljZVJvdywgd2l0aFRpZXJzUm93OiB3aXRoVGllcnNSb3csIHdpdGhUcmlhbExlZnRSb3c6IHdpdGhUcmlhbExlZnRSb3csIGtleTogcGxhbi5pZCwgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbjogc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIHBsYW46IHBsYW4sIHdpdGhTdGFydGluZ0F0Um93OiB3aXRoU3RhcnRpbmdBdFJvdywgY3VycmVudFN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbiwgY3VycmVudFN1YnNjcmlwdGlvbk92ZXJyaWRlOiBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2203
2259
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
2204
2260
  });
2205
2261
 
@@ -2209,7 +2265,7 @@ var PaywallLayout = /*#__PURE__*/_styled("div", {
2209
2265
  })( {
2210
2266
  name: "zigog8",
2211
2267
  styles: "display:flex;flex-direction:column;align-items:center",
2212
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCaUMiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc3RpZ2cgfSA9IHVzZVN0aWdnQ29udGV4dCgpO1xyXG4gICAgY29uc3QgZGlzY291bnRSYXRlID0gY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZShwbGFucyk7XHJcbiAgICBjb25zdCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uID0gcGxhbnMuc29tZSgocGxhbikgPT4gISFwbGFuLmRlc2NyaXB0aW9uKTtcclxuICAgIGNvbnN0IGhhc01vbnRobHlQcmljZSA9IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMocGxhbnMsIEJpbGxpbmdQZXJpb2QuTW9udGhseSk7XHJcbiAgICBjb25zdCBoYXNBbm51YWxseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Bbm51YWxseSk7XHJcbiAgICBjb25zdCBwbGFuc1RvU2hvdyA9IGdldFBsYW5zVG9EaXNwbGF5KHBsYW5zLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHNob3VsZEhpZGVQbGFuKTtcclxuICAgIGNvbnN0IGhhbmRsZU9uU3Vic2NyaWJlID0gdXNlQ2FsbGJhY2soKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IHtcclxuICAgICAgICByZXR1cm4gb25QbGFuU2VsZWN0ZWQoe1xyXG4gICAgICAgICAgICBwbGFuLFxyXG4gICAgICAgICAgICBjdXN0b21lcixcclxuICAgICAgICAgICAgc3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLFxyXG4gICAgICAgICAgICBpbnRlbnRpb25UeXBlLFxyXG4gICAgICAgICAgICBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgIGJpbGxhYmxlRmVhdHVyZXMsXHJcbiAgICAgICAgfSk7XHJcbiAgICB9LCBbY3VzdG9tZXIsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgY3VycmVudFN1YnNjcmlwdGlvbiwgb25QbGFuU2VsZWN0ZWRdKTtcclxuICAgIGNvbnN0IGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4gPSAhIWN1cnJlbnRTdWJzY3JpcHRpb24gJiYgY3VycmVudFN1YnNjcmlwdGlvbi5wbGFuLnByaWNpbmdUeXBlID09PSBQcmljaW5nVHlwZS5DdXN0b207XHJcbiAgICBjb25zdCB3aXRoU3RhcnRpbmdBdFJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHBsYW5QcmljZXMgPSBwbGFuLnByaWNlUG9pbnRzLmZpbHRlcigocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIGNvbnN0IHBheXdhbGxDYWxjdWxhdGVkUHJpY2UgPSBwbGFuLnBheXdhbGxDYWxjdWxhdGVkUHJpY2VQb2ludHM/LmZpbmQoKHByaWNlUG9pbnQpID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlcy5sZW5ndGggPiAxICYmICEhcGF5d2FsbENhbGN1bGF0ZWRQcmljZT8uYWRkaXRpb25hbENoYXJnZXNNYXlBcHBseTtcclxuICAgIH0pLCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFVuaXRQcmljZVJvdyA9IHVzZU1lbW8oKCkgPT4gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiAhIWdldFBsYW5QcmljZShwbGFuLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlKS51bml0O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGhhc01vbnRobHlQcmljZSwgbG9jYWxlLCBwYXl3YWxsTG9jYWxlLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRpZXJzUm93ID0gdXNlTWVtbygoKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICghaXNDdXN0b21lckluQ3VzdG9tUGxhbiAmJlxyXG4gICAgICAgICAgICBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBjb25zdCB0aWVycyA9IGdldFRpZXJzUGVyVW5pdFF1YW50aXRpZXMocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uKTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBpc0N1c3RvbWVySW5DdXN0b21QbGFuLCBwbGFuc1RvU2hvd10pO1xyXG4gICAgY29uc3Qgd2l0aFRyaWFsTGVmdFJvdyA9IHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhbi5pc0N1cnJlbnRDdXN0b21lclBsYW4gJiYgcGxhbi50cmlhbERheXNMZWZ0O1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbENvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbExheW91dCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1sYXlvdXRcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJpbGxpbmdQZXJpb2RQaWNrZXIsIHsgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZDogb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzOiBhdmFpbGFibGVCaWxsaW5nUGVyaW9kcywgZGlzY291bnRSYXRlOiBkaXNjb3VudFJhdGUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbFBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLXBsYW5zLWxheW91dFwiIH0sIHBsYW5zVG9TaG93Lm1hcCgocGxhbikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nLCB7IHdpdGhVbml0UHJpY2VSb3c6IHdpdGhVbml0UHJpY2VSb3csIHdpdGhUaWVyc1Jvdzogd2l0aFRpZXJzUm93LCB3aXRoVHJpYWxMZWZ0Um93OiB3aXRoVHJpYWxMZWZ0Um93LCBrZXk6IHBsYW4uaWQsIHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb246IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24sIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBwbGFuOiBwbGFuLCB3aXRoU3RhcnRpbmdBdFJvdzogd2l0aFN0YXJ0aW5nQXRSb3csIGN1cnJlbnRTdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2268
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCaUMiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kLCBQcmljaW5nVHlwZSB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFBsYW5PZmZlcmluZyB9IGZyb20gJy4vUGxhbk9mZmVyaW5nJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZFBpY2tlciB9IGZyb20gJy4vQmlsbGluZ1BlcmlvZFBpY2tlcic7XHJcbmltcG9ydCB7IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUgfSBmcm9tICcuLi91dGlscy9jYWxjdWxhdGVEaXNjb3VudFJhdGUnO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmltcG9ydCB7IHVzZVN0aWdnQ29udGV4dCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgaGFzUHJpY2VQb2ludHNGb3JQbGFucyB9IGZyb20gJy4vdXRpbHMvaGFzUHJpY2VQb2ludHMnO1xyXG5pbXBvcnQgeyBnZXRQbGFuc1RvRGlzcGxheSB9IGZyb20gJy4vdXRpbHMvZ2V0UGxhbnNUb0Rpc3BsYXknO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBnZXRUaWVyc1BlclVuaXRRdWFudGl0aWVzIH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5jb25zdCBQYXl3YWxsUGxhbnNDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnByaW1hcnl9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogc3RyZXRjaDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgcGFkZGluZzogMTBweCAwO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuYDtcclxuY29uc3QgUGF5d2FsbENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuY29uc3QgUGF5d2FsbExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFBheXdhbGwgPSAoeyBwbGFucywgY3VzdG9tZXIsIGN1cnJlbnRTdWJzY3JpcHRpb24sIGhpZ2hsaWdodGVkUGxhbklkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIG9uQmlsbGluZ1BlcmlvZENoYW5nZWQsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgc2hvdWxkSGlkZVBsYW4sIHNlbGVjdERlZmF1bHRUaWVySW5kZXgsIGN1cnJlbnRTdWJzY3JpcHRpb25PdmVycmlkZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdGlnZyB9ID0gdXNlU3RpZ2dDb250ZXh0KCk7XHJcbiAgICBjb25zdCBkaXNjb3VudFJhdGUgPSBjYWxjdWxhdGVQYXl3YWxsRGlzY291bnRSYXRlKHBsYW5zKTtcclxuICAgIGNvbnN0IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24gPSBwbGFucy5zb21lKChwbGFuKSA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgc2hvdWxkSGlkZVBsYW4pO1xyXG4gICAgY29uc3QgaGFuZGxlT25TdWJzY3JpYmUgPSB1c2VDYWxsYmFjaygocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4ge1xyXG4gICAgICAgIHJldHVybiBvblBsYW5TZWxlY3RlZCh7XHJcbiAgICAgICAgICAgIHBsYW4sXHJcbiAgICAgICAgICAgIGN1c3RvbWVyLFxyXG4gICAgICAgICAgICBzdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sXHJcbiAgICAgICAgICAgIGludGVudGlvblR5cGUsXHJcbiAgICAgICAgICAgIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgYmlsbGFibGVGZWF0dXJlcyxcclxuICAgICAgICB9KTtcclxuICAgIH0sIFtjdXN0b21lciwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBvblBsYW5TZWxlY3RlZF0pO1xyXG4gICAgY29uc3QgaXNDdXN0b21lckluQ3VzdG9tUGxhbiA9ICEhY3VycmVudFN1YnNjcmlwdGlvbiAmJiBjdXJyZW50U3Vic2NyaXB0aW9uLnBsYW4ucHJpY2luZ1R5cGUgPT09IFByaWNpbmdUeXBlLkN1c3RvbTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgY29uc3QgcGxhblByaWNlcyA9IHBsYW4ucHJpY2VQb2ludHMuZmlsdGVyKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2VzLmxlbmd0aCA+IDEgJiYgISFwYXl3YWxsQ2FsY3VsYXRlZFByaWNlPy5hZGRpdGlvbmFsQ2hhcmdlc01heUFwcGx5O1xyXG4gICAgfSksIFtzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVW5pdFByaWNlUm93ID0gdXNlTWVtbygoKSA9PiBwbGFuc1RvU2hvdy5zb21lKChwbGFuKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KSwgW3NlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBsb2NhbGUsIHBheXdhbGxMb2NhbGUsIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVGllcnNSb3cgPSB1c2VNZW1vKCgpID0+IHtcclxuICAgICAgICByZXR1cm4gKCFpc0N1c3RvbWVySW5DdXN0b21QbGFuICYmXHJcbiAgICAgICAgICAgIHBsYW5zVG9TaG93LnNvbWUoKHBsYW4pID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IHRpZXJzID0gZ2V0VGllcnNQZXJVbml0UXVhbnRpdGllcyh7XHJcbiAgICAgICAgICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgICAgICAgICBiaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgICAgICAgICAgY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsXHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHRpZXJzKS5sZW5ndGggPiAwO1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGlzQ3VzdG9tZXJJbkN1c3RvbVBsYW4sIHBsYW5zVG9TaG93XSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZSgocGxhbikgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuLmlzQ3VycmVudEN1c3RvbWVyUGxhbiAmJiBwbGFuLnRyaWFsRGF5c0xlZnQ7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsTGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWxheW91dFwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZFBpY2tlciwgeyBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkOiBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHM6IGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBkaXNjb3VudFJhdGU6IGRpc2NvdW50UmF0ZSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtcGxhbnMtbGF5b3V0XCIgfSwgcGxhbnNUb1Nob3cubWFwKChwbGFuKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmcsIHsgd2l0aFVuaXRQcmljZVJvdzogd2l0aFVuaXRQcmljZVJvdywgd2l0aFRpZXJzUm93OiB3aXRoVGllcnNSb3csIHdpdGhUcmlhbExlZnRSb3c6IHdpdGhUcmlhbExlZnRSb3csIGtleTogcGxhbi5pZCwgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbjogc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIHBsYW46IHBsYW4sIHdpdGhTdGFydGluZ0F0Um93OiB3aXRoU3RhcnRpbmdBdFJvdywgY3VycmVudFN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbiwgY3VycmVudFN1YnNjcmlwdGlvbk92ZXJyaWRlOiBjdXJyZW50U3Vic2NyaXB0aW9uT3ZlcnJpZGUsIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciwgaXNDdXN0b21lckluQ3VzdG9tUGxhbjogaXNDdXN0b21lckluQ3VzdG9tUGxhbiwgc2VsZWN0RGVmYXVsdFRpZXJJbmRleDogc2VsZWN0RGVmYXVsdFRpZXJJbmRleCB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */",
2213
2269
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
2214
2270
  });
2215
2271
 
@@ -2226,7 +2282,8 @@ var Paywall = function Paywall(_ref3) {
2226
2282
  paywallLocale = _ref3.paywallLocale,
2227
2283
  locale = _ref3.locale,
2228
2284
  shouldHidePlan = _ref3.shouldHidePlan,
2229
- selectDefaultTierIndex = _ref3.selectDefaultTierIndex;
2285
+ selectDefaultTierIndex = _ref3.selectDefaultTierIndex,
2286
+ currentSubscriptionOverride = _ref3.currentSubscriptionOverride;
2230
2287
 
2231
2288
  var _useStiggContext = useStiggContext(),
2232
2289
  stigg = _useStiggContext.stigg;
@@ -2269,10 +2326,15 @@ var Paywall = function Paywall(_ref3) {
2269
2326
  }, [selectedBillingPeriod, hasMonthlyPrice, locale, paywallLocale, plansToShow]);
2270
2327
  var withTiersRow = React.useMemo(function () {
2271
2328
  return !isCustomerInCustomPlan && plansToShow.some(function (plan) {
2272
- var tiers = getTiersPerUnitQuantities(plan, selectedBillingPeriod, currentSubscription);
2329
+ var tiers = getTiersPerUnitQuantities({
2330
+ plan: plan,
2331
+ billingPeriod: selectedBillingPeriod,
2332
+ currentSubscription: currentSubscription,
2333
+ currentSubscriptionOverride: currentSubscriptionOverride
2334
+ });
2273
2335
  return Object.values(tiers).length > 0;
2274
2336
  });
2275
- }, [selectedBillingPeriod, currentSubscription, isCustomerInCustomPlan, plansToShow]);
2337
+ }, [selectedBillingPeriod, currentSubscription, currentSubscriptionOverride, isCustomerInCustomPlan, plansToShow]);
2276
2338
  var withTrialLeftRow = plansToShow.some(function (plan) {
2277
2339
  return plan.isCurrentCustomerPlan && plan.trialDaysLeft;
2278
2340
  });
@@ -2299,6 +2361,7 @@ var Paywall = function Paywall(_ref3) {
2299
2361
  plan: plan,
2300
2362
  withStartingAtRow: withStartingAtRow,
2301
2363
  currentSubscription: currentSubscription,
2364
+ currentSubscriptionOverride: currentSubscriptionOverride,
2302
2365
  billingPeriod: selectedBillingPeriod,
2303
2366
  isHighlighted: plan.id === highlightedPlanId,
2304
2367
  isCustomerOnTrial: isCustomerOnTrial,
@@ -3330,7 +3393,7 @@ function getCustomerSubscriptionDetails(activeSubscriptions) {
3330
3393
  };
3331
3394
  }
3332
3395
 
3333
- function mapPaywallData(paywall, showOnlyEligiblePlans) {
3396
+ function mapPaywallData(paywall, showOnlyEligiblePlans, currentSubscriptionOverrideFn) {
3334
3397
  var _currentSubscription$;
3335
3398
 
3336
3399
  var _ref = paywall || {},
@@ -3347,6 +3410,9 @@ function mapPaywallData(paywall, showOnlyEligiblePlans) {
3347
3410
  isCustomerOnTrial = _getCustomerSubscript.isCustomerOnTrial,
3348
3411
  trialDaysLeft = _getCustomerSubscript.trialDaysLeft;
3349
3412
 
3413
+ var currentSubscriptionOverride = currentSubscriptionOverrideFn == null ? void 0 : currentSubscriptionOverrideFn({
3414
+ currentSubscription: currentSubscription
3415
+ });
3350
3416
  var scheduledUpdates = (currentSubscription == null ? void 0 : currentSubscription.scheduledUpdates) || [];
3351
3417
  var currentCustomerPlanBillingPeriod = currentSubscription == null ? void 0 : (_currentSubscription$ = currentSubscription.price) == null ? void 0 : _currentSubscription$.billingPeriod;
3352
3418
  var downgradeSchedule = scheduledUpdates.find(function (_ref2) {
@@ -3365,7 +3431,7 @@ function mapPaywallData(paywall, showOnlyEligiblePlans) {
3365
3431
  var eligibleForProductTrial = customer == null ? void 0 : (_customer$eligibleFor = customer.eligibleForTrial) == null ? void 0 : _customer$eligibleFor.find(function (productTrial) {
3366
3432
  return productTrial.productId === plan.product.id;
3367
3433
  });
3368
- var isCurrentCustomerPlan = plan.id === (currentPlan == null ? void 0 : currentPlan.id);
3434
+ var isCurrentCustomerPlan = currentSubscriptionOverride != null && currentSubscriptionOverride.planId ? (currentSubscriptionOverride == null ? void 0 : currentSubscriptionOverride.planId) === plan.id : plan.id === (currentPlan == null ? void 0 : currentPlan.id);
3369
3435
 
3370
3436
  var isNextPlan = function isNextPlan(currentBillingPeriod) {
3371
3437
  var _downgradeSchedule$ta;
@@ -3419,13 +3485,14 @@ function mapPaywallData(paywall, showOnlyEligiblePlans) {
3419
3485
  return {
3420
3486
  currentPlan: currentPlan,
3421
3487
  currentSubscription: currentSubscription,
3488
+ currentSubscriptionOverride: currentSubscriptionOverride,
3422
3489
  isCustomerOnTrial: isCustomerOnTrial,
3423
3490
  plans: paywallPlans,
3424
3491
  paywallConfiguration: paywallConfiguration
3425
3492
  };
3426
3493
  }
3427
3494
 
3428
- var version = "5.28.4";
3495
+ var version = "5.29.0";
3429
3496
  var name = "@stigg/react-sdk";
3430
3497
 
3431
3498
  var StiggContext = /*#__PURE__*/React__default.createContext(null);
@@ -3635,7 +3702,8 @@ function useLoadPaywallData(_ref) {
3635
3702
  resourceId = _ref.resourceId,
3636
3703
  showOnlyEligiblePlans = _ref.showOnlyEligiblePlans,
3637
3704
  billingCountryCode = _ref.billingCountryCode,
3638
- preferredBillingPeriod = _ref.preferredBillingPeriod;
3705
+ preferredBillingPeriod = _ref.preferredBillingPeriod,
3706
+ currentSubscriptionOverrideFn = _ref.currentSubscriptionOverrideFn;
3639
3707
 
3640
3708
  var _useStiggContext = useStiggContext(),
3641
3709
  stigg = _useStiggContext.stigg,
@@ -3713,7 +3781,7 @@ function useLoadPaywallData(_ref) {
3713
3781
 
3714
3782
  void loadPaywall();
3715
3783
  }, [stigg, productId, stigg.isCustomerLoaded, billingCountryCode, resourceId, preferredBillingPeriod]);
3716
- var paywallData = mapPaywallData(paywall, showOnlyEligiblePlans);
3784
+ var paywallData = mapPaywallData(paywall, showOnlyEligiblePlans, currentSubscriptionOverrideFn);
3717
3785
  return _extends({
3718
3786
  customer: (paywall == null ? void 0 : paywall.customer) || null,
3719
3787
  isLoading: isLoading,
@@ -4143,7 +4211,8 @@ var PaywallContainer$1 = function PaywallContainer(_ref) {
4143
4211
  onBillingPeriodChange = _ref.onBillingPeriodChange,
4144
4212
  billingCountryCode = _ref.billingCountryCode,
4145
4213
  shouldHidePlan = _ref.shouldHidePlan,
4146
- selectDefaultTierIndex = _ref.selectDefaultTierIndex;
4214
+ selectDefaultTierIndex = _ref.selectDefaultTierIndex,
4215
+ currentSubscriptionOverrideFn = _ref.currentSubscriptionOverride;
4147
4216
  var hasCustomerPortalContext = useCheckContextExists(CustomerPortalContext);
4148
4217
  var isCustomerPortalLoading = false;
4149
4218
 
@@ -4162,11 +4231,13 @@ var PaywallContainer$1 = function PaywallContainer(_ref) {
4162
4231
  resourceId: resourceId,
4163
4232
  showOnlyEligiblePlans: showOnlyEligiblePlans,
4164
4233
  billingCountryCode: billingCountryCode,
4165
- preferredBillingPeriod: preferredBillingPeriod
4234
+ preferredBillingPeriod: preferredBillingPeriod,
4235
+ currentSubscriptionOverrideFn: currentSubscriptionOverrideFn
4166
4236
  }),
4167
4237
  plans = _useLoadPaywallData.plans,
4168
4238
  customer = _useLoadPaywallData.customer,
4169
4239
  currentSubscription = _useLoadPaywallData.currentSubscription,
4240
+ currentSubscriptionOverride = _useLoadPaywallData.currentSubscriptionOverride,
4170
4241
  isCustomerOnTrial = _useLoadPaywallData.isCustomerOnTrial,
4171
4242
  isLoading = _useLoadPaywallData.isLoading,
4172
4243
  selectedBillingPeriod = _useLoadPaywallData.selectedBillingPeriod,
@@ -4189,6 +4260,7 @@ var PaywallContainer$1 = function PaywallContainer(_ref) {
4189
4260
  plans: plans,
4190
4261
  customer: customer,
4191
4262
  currentSubscription: currentSubscription,
4263
+ currentSubscriptionOverride: currentSubscriptionOverride,
4192
4264
  selectedBillingPeriod: selectedBillingPeriod,
4193
4265
  onBillingPeriodChanged: handlePeriodChange,
4194
4266
  availableBillingPeriods: availableBillingPeriods,