@stigg/react-sdk 4.1.2 → 4.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/paywall/PlanOffering.d.ts +6 -4
- package/dist/components/paywall/PlanOfferingButton.d.ts +5 -2
- package/dist/components/paywall/PlanPrice.d.ts +18 -0
- package/dist/components/paywall/TiersLayout.d.ts +10 -0
- package/dist/components/paywall/paywallTextOverrides.d.ts +12 -1
- package/dist/components/paywall/planPriceTier.d.ts +10 -0
- package/dist/components/paywall/types.d.ts +4 -2
- package/dist/components/utils/getPaidPriceText.d.ts +3 -2
- package/dist/components/utils/getPlanPrice.d.ts +4 -2
- package/dist/react-sdk.cjs.development.js +593 -288
- package/dist/react-sdk.cjs.development.js.map +1 -1
- package/dist/react-sdk.cjs.production.min.js +1 -1
- package/dist/react-sdk.cjs.production.min.js.map +1 -1
- package/dist/react-sdk.esm.js +610 -301
- package/dist/react-sdk.esm.js.map +1 -1
- package/package.json +2 -2
- package/src/components/paywall/Paywall.tsx +17 -3
- package/src/components/paywall/PlanOffering.tsx +37 -104
- package/src/components/paywall/PlanOfferingButton.tsx +37 -11
- package/src/components/paywall/PlanPrice.tsx +152 -0
- package/src/components/paywall/TiersLayout.tsx +74 -0
- package/src/components/paywall/paywallTextOverrides.ts +9 -1
- package/src/components/paywall/planPriceTier.ts +105 -0
- package/src/components/paywall/types.ts +4 -0
- package/src/components/utils/getPaidPriceText.ts +42 -18
- package/src/components/utils/getPlanPrice.ts +10 -2
|
@@ -9,7 +9,6 @@ var Stigg__default = _interopDefault(Stigg);
|
|
|
9
9
|
var React = require('react');
|
|
10
10
|
var React__default = _interopDefault(React);
|
|
11
11
|
var _styled = _interopDefault(require('@emotion/styled/base'));
|
|
12
|
-
var getSymbolFromCurrency = _interopDefault(require('currency-symbol-map'));
|
|
13
12
|
var styledTypography = require('styled-typography');
|
|
14
13
|
var react = require('@emotion/react');
|
|
15
14
|
var Color = _interopDefault(require('color'));
|
|
@@ -20,6 +19,7 @@ var isNil = _interopDefault(require('lodash/isNil'));
|
|
|
20
19
|
var lodash = require('lodash');
|
|
21
20
|
var classNames = _interopDefault(require('classnames'));
|
|
22
21
|
var material = require('@mui/material');
|
|
22
|
+
var getSymbolFromCurrency = _interopDefault(require('currency-symbol-map'));
|
|
23
23
|
var Switch = _interopDefault(require('react-switch'));
|
|
24
24
|
var Skeleton = require('react-loading-skeleton');
|
|
25
25
|
var Skeleton__default = _interopDefault(Skeleton);
|
|
@@ -116,130 +116,42 @@ function _taggedTemplateLiteralLoose(strings, raw) {
|
|
|
116
116
|
return strings;
|
|
117
117
|
}
|
|
118
118
|
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
var currencySymbol = getSymbolFromCurrency(currencyString);
|
|
128
|
-
var formattedPrice = new Intl.NumberFormat(locale, _extends({
|
|
129
|
-
maximumFractionDigits: maximumFractionDigits,
|
|
130
|
-
minimumFractionDigits: 0,
|
|
131
|
-
style: 'currency',
|
|
132
|
-
currency: currencyString
|
|
133
|
-
}, currencySymbol ? {
|
|
134
|
-
currencyDisplay: 'code'
|
|
135
|
-
} : {})).format(amount || 0);
|
|
136
|
-
|
|
137
|
-
if (currencySymbol) {
|
|
138
|
-
formattedPrice = formattedPrice.replace(currencyString, currencySymbol);
|
|
139
|
-
} // remove space between currency symbol and price
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
formattedPrice = formattedPrice.replace(/\s/g, '');
|
|
143
|
-
return formattedPrice;
|
|
144
|
-
};
|
|
145
|
-
|
|
146
|
-
function getPaidPriceText(_ref) {
|
|
147
|
-
var planPrices = _ref.planPrices,
|
|
148
|
-
paywallCalculatedPrice = _ref.paywallCalculatedPrice,
|
|
149
|
-
selectedBillingPeriod = _ref.selectedBillingPeriod,
|
|
150
|
-
locale = _ref.locale,
|
|
151
|
-
shouldShowMonthlyPriceAmount = _ref.shouldShowMonthlyPriceAmount;
|
|
152
|
-
|
|
153
|
-
var _ref2 = paywallCalculatedPrice || planPrices[0],
|
|
154
|
-
amount = _ref2.amount,
|
|
155
|
-
currency = _ref2.currency;
|
|
156
|
-
|
|
157
|
-
var isSinglePrice = planPrices.length === 1;
|
|
158
|
-
var priceNumber = selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? amount / 12 : amount;
|
|
159
|
-
var priceString = currencyPriceFormatter({
|
|
160
|
-
amount: priceNumber,
|
|
161
|
-
currency: currency,
|
|
162
|
-
locale: locale
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
if (isSinglePrice) {
|
|
166
|
-
var price = planPrices[0];
|
|
167
|
-
|
|
168
|
-
if (price.pricingModel === Stigg.BillingModel.PerUnit) {
|
|
169
|
-
var _price$feature;
|
|
119
|
+
function _unsupportedIterableToArray(o, minLen) {
|
|
120
|
+
if (!o) return;
|
|
121
|
+
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
|
|
122
|
+
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
123
|
+
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
124
|
+
if (n === "Map" || n === "Set") return Array.from(o);
|
|
125
|
+
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
|
|
126
|
+
}
|
|
170
127
|
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
price: priceString,
|
|
174
|
-
unit: shouldShowMonthlyPriceAmount ? "per " + featureUnit + " / month" : "per " + featureUnit + " / year"
|
|
175
|
-
};
|
|
176
|
-
} else if (price.pricingModel === Stigg.BillingModel.UsageBased) {
|
|
177
|
-
var _price$feature2;
|
|
128
|
+
function _arrayLikeToArray(arr, len) {
|
|
129
|
+
if (len == null || len > arr.length) len = arr.length;
|
|
178
130
|
|
|
179
|
-
|
|
131
|
+
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
|
|
180
132
|
|
|
181
|
-
|
|
182
|
-
price: priceString,
|
|
183
|
-
unit: "per " + _featureUnit
|
|
184
|
-
};
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
return {
|
|
189
|
-
price: priceString,
|
|
190
|
-
unit: shouldShowMonthlyPriceAmount ? '/ month' : '/ year'
|
|
191
|
-
};
|
|
133
|
+
return arr2;
|
|
192
134
|
}
|
|
193
135
|
|
|
194
|
-
function
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
if (typeof paywallLocale.price.free === 'function') {
|
|
198
|
-
return paywallLocale.price.free(plan.paywallCurrency);
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
return paywallLocale.price.free;
|
|
136
|
+
function _createForOfIteratorHelperLoose(o, allowArrayLike) {
|
|
137
|
+
var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
|
|
138
|
+
if (it) return (it = it.call(o)).next.bind(it);
|
|
202
139
|
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
140
|
+
if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
|
|
141
|
+
if (it) o = it;
|
|
142
|
+
var i = 0;
|
|
143
|
+
return function () {
|
|
144
|
+
if (i >= o.length) return {
|
|
145
|
+
done: true
|
|
206
146
|
};
|
|
207
|
-
|
|
208
|
-
case Stigg.PricingType.Paid:
|
|
209
|
-
{
|
|
210
|
-
var _plan$paywallCalculat;
|
|
211
|
-
|
|
212
|
-
var planPrices = plan.pricePoints.filter(function (pricePoint) {
|
|
213
|
-
return pricePoint.billingPeriod === billingPeriod;
|
|
214
|
-
});
|
|
215
|
-
var paywallCalculatedPrice = (_plan$paywallCalculat = plan.paywallCalculatedPricePoints) == null ? void 0 : _plan$paywallCalculat.find(function (pricePoint) {
|
|
216
|
-
return pricePoint.billingPeriod === billingPeriod;
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
if (!(planPrices != null && planPrices.length) && !paywallCalculatedPrice) {
|
|
220
|
-
return {
|
|
221
|
-
price: paywallLocale.price.priceNotSet
|
|
222
|
-
};
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
var paidParams = {
|
|
226
|
-
planPrices: planPrices,
|
|
227
|
-
paywallCalculatedPrice: paywallCalculatedPrice,
|
|
228
|
-
selectedBillingPeriod: billingPeriod
|
|
229
|
-
};
|
|
230
|
-
return paywallLocale.price.paid ? paywallLocale.price.paid(_extends({}, paidParams, {
|
|
231
|
-
plan: plan
|
|
232
|
-
})) : getPaidPriceText(_extends({}, paidParams, {
|
|
233
|
-
locale: locale,
|
|
234
|
-
shouldShowMonthlyPriceAmount: shouldShowMonthlyPriceAmount
|
|
235
|
-
}));
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
default:
|
|
239
147
|
return {
|
|
240
|
-
|
|
148
|
+
done: false,
|
|
149
|
+
value: o[i++]
|
|
241
150
|
};
|
|
151
|
+
};
|
|
242
152
|
}
|
|
153
|
+
|
|
154
|
+
throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
243
155
|
}
|
|
244
156
|
|
|
245
157
|
var _path;
|
|
@@ -578,6 +490,7 @@ function PlanEntitlements(_ref) {
|
|
|
578
490
|
SubscribeIntentionType["UPGRADE_TRIAL_TO_PAID"] = "UPGRADE_TRIAL_TO_PAID";
|
|
579
491
|
SubscribeIntentionType["REQUEST_CUSTOM_PLAN_ACCESS"] = "REQUEST_CUSTOM_PLAN_ACCESS";
|
|
580
492
|
SubscribeIntentionType["CHANGE_BILLING_PERIOD"] = "CHANGE_BILLING_PERIOD";
|
|
493
|
+
SubscribeIntentionType["CHANGE_UNIT_QUANTITY"] = "CHANGE_UNIT_QUANTITY";
|
|
581
494
|
SubscribeIntentionType["UPGRADE_PLAN"] = "UPGRADE_PLAN";
|
|
582
495
|
SubscribeIntentionType["DOWNGRADE_PLAN"] = "DOWNGRADE_PLAN";
|
|
583
496
|
SubscribeIntentionType["CANCEL_SCHEDULED_UPDATES"] = "CANCEL_SCHEDULED_UPDATES";
|
|
@@ -745,6 +658,99 @@ function getSubscriptionScheduleUpdateTexts(_ref) {
|
|
|
745
658
|
}
|
|
746
659
|
}
|
|
747
660
|
|
|
661
|
+
function calculateTierPrice(price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
662
|
+
switch (price.tiersMode) {
|
|
663
|
+
case Stigg.TiersMode.Volume:
|
|
664
|
+
var unitPrice = selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? currentTier.unitPrice.amount / 12 : currentTier.unitPrice.amount;
|
|
665
|
+
return unitPrice * currentTier.upTo;
|
|
666
|
+
}
|
|
667
|
+
|
|
668
|
+
return 0;
|
|
669
|
+
}
|
|
670
|
+
function getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature) {
|
|
671
|
+
var planTierPrices = plan.pricePoints.filter(function (price) {
|
|
672
|
+
return price.billingPeriod === billingPeriod && price.isTieredPrice;
|
|
673
|
+
});
|
|
674
|
+
|
|
675
|
+
if (planTierPrices.length == 1) {
|
|
676
|
+
var price = planTierPrices[0];
|
|
677
|
+
var featureId = price.feature.featureId;
|
|
678
|
+
var currentTier = price.tiers[0];
|
|
679
|
+
|
|
680
|
+
if (selectedTierByFeature[featureId]) {
|
|
681
|
+
var _price$tiers;
|
|
682
|
+
|
|
683
|
+
currentTier = ((_price$tiers = price.tiers) == null ? void 0 : _price$tiers.find(function (tier) {
|
|
684
|
+
return tier.upTo === selectedTierByFeature[featureId].upTo;
|
|
685
|
+
})) || currentTier;
|
|
686
|
+
} else if (currentSubscription) {
|
|
687
|
+
var tieredPrice = currentSubscription.prices.find(function (subscriptionPrice) {
|
|
688
|
+
var _subscriptionPrice$fe;
|
|
689
|
+
|
|
690
|
+
return subscriptionPrice.pricingModel == Stigg.BillingModel.PerUnit && subscriptionPrice.billingPeriod == billingPeriod && subscriptionPrice.tiersMode && ((_subscriptionPrice$fe = subscriptionPrice.feature) == null ? void 0 : _subscriptionPrice$fe.featureId) === featureId;
|
|
691
|
+
});
|
|
692
|
+
|
|
693
|
+
if (tieredPrice) {
|
|
694
|
+
var customerTier = tieredPrice.tiers.find(function (tier) {
|
|
695
|
+
return tier.upTo === tieredPrice.feature.unitQuantity;
|
|
696
|
+
});
|
|
697
|
+
currentTier = customerTier || tieredPrice.tiers[0];
|
|
698
|
+
}
|
|
699
|
+
}
|
|
700
|
+
|
|
701
|
+
var result = {};
|
|
702
|
+
result[featureId] = currentTier;
|
|
703
|
+
return result;
|
|
704
|
+
}
|
|
705
|
+
|
|
706
|
+
return {};
|
|
707
|
+
}
|
|
708
|
+
var PriceTierComparison;
|
|
709
|
+
|
|
710
|
+
(function (PriceTierComparison) {
|
|
711
|
+
PriceTierComparison[PriceTierComparison["Lower"] = -1] = "Lower";
|
|
712
|
+
PriceTierComparison[PriceTierComparison["Equal"] = 0] = "Equal";
|
|
713
|
+
PriceTierComparison[PriceTierComparison["Higher"] = 1] = "Higher";
|
|
714
|
+
})(PriceTierComparison || (PriceTierComparison = {}));
|
|
715
|
+
|
|
716
|
+
function compareSelectedTierToCurrentTier(selectedTierByFeature, currentSubscription) {
|
|
717
|
+
if (!currentSubscription || !selectedTierByFeature) {
|
|
718
|
+
return PriceTierComparison.Equal;
|
|
719
|
+
}
|
|
720
|
+
|
|
721
|
+
var currentTierPrice = currentSubscription.prices.find(function (price) {
|
|
722
|
+
return price.pricingModel == Stigg.BillingModel.PerUnit && price.tiersMode;
|
|
723
|
+
});
|
|
724
|
+
|
|
725
|
+
if (!currentTierPrice) {
|
|
726
|
+
return PriceTierComparison.Equal;
|
|
727
|
+
}
|
|
728
|
+
|
|
729
|
+
var _currentTierPrice$fea = currentTierPrice.feature,
|
|
730
|
+
featureId = _currentTierPrice$fea.featureId,
|
|
731
|
+
unitQuantity = _currentTierPrice$fea.unitQuantity;
|
|
732
|
+
|
|
733
|
+
if (!unitQuantity) {
|
|
734
|
+
return PriceTierComparison.Equal;
|
|
735
|
+
}
|
|
736
|
+
|
|
737
|
+
var selectedTier = selectedTierByFeature[featureId];
|
|
738
|
+
|
|
739
|
+
if (!selectedTier) {
|
|
740
|
+
return PriceTierComparison.Equal;
|
|
741
|
+
}
|
|
742
|
+
|
|
743
|
+
if (selectedTier.upTo < unitQuantity) {
|
|
744
|
+
return PriceTierComparison.Lower;
|
|
745
|
+
}
|
|
746
|
+
|
|
747
|
+
if (selectedTier.upTo > unitQuantity) {
|
|
748
|
+
return PriceTierComparison.Higher;
|
|
749
|
+
}
|
|
750
|
+
|
|
751
|
+
return PriceTierComparison.Equal;
|
|
752
|
+
}
|
|
753
|
+
|
|
748
754
|
var _templateObject;
|
|
749
755
|
|
|
750
756
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
@@ -755,7 +761,7 @@ var LoadingIndicator = /*#__PURE__*/_styled(ClipLoader, {
|
|
|
755
761
|
})( {
|
|
756
762
|
name: "1a2afmv",
|
|
757
763
|
styles: "margin-left:10px",
|
|
758
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAU4C","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\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: 40px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, }) {\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            buttonProps.title = currentPlan;\r\n            buttonProps.disabled = true;\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 = 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            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"]} */",
|
|
764
|
+
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 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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from './planPriceTier';\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, hasTiersRow, withTrialLeftRow, currentSubscription, selectedTierByFeature, }) {\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(selectedTierByFeature, 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 = 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            hasTiersRow && !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"]} */",
|
|
759
765
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
760
766
|
});
|
|
761
767
|
|
|
@@ -778,7 +784,7 @@ var OfferingButton = /*#__PURE__*/_styled("button", {
|
|
|
778
784
|
var theme = _ref5.theme,
|
|
779
785
|
$disabled = _ref5.$disabled;
|
|
780
786
|
return $disabled ? theme.stigg.palette.backgroundButton : theme.stigg.palette.outlinedHoverBackground;
|
|
781
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAaqC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\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: 40px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, }) {\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            buttonProps.title = currentPlan;\r\n            buttonProps.disabled = true;\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 = 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            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"]} */"));
|
|
787
|
+
}, ";}" + ( "/*# 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 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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from './planPriceTier';\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, hasTiersRow, withTrialLeftRow, currentSubscription, selectedTierByFeature, }) {\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(selectedTierByFeature, 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 = 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            hasTiersRow && !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"]} */"));
|
|
782
788
|
|
|
783
789
|
var ButtonText = /*#__PURE__*/_styled(Typography, {
|
|
784
790
|
target: "e199qof94",
|
|
@@ -786,7 +792,7 @@ var ButtonText = /*#__PURE__*/_styled(Typography, {
|
|
|
786
792
|
})( {
|
|
787
793
|
name: "h05omw",
|
|
788
794
|
styles: "margin:0;font-size:15px",
|
|
789
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAkCsC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\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: 40px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, }) {\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            buttonProps.title = currentPlan;\r\n            buttonProps.disabled = true;\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 = 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            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"]} */",
|
|
795
|
+
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 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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from './planPriceTier';\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, hasTiersRow, withTrialLeftRow, currentSubscription, selectedTierByFeature, }) {\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(selectedTierByFeature, 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 = 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            hasTiersRow && !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"]} */",
|
|
790
796
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
791
797
|
});
|
|
792
798
|
|
|
@@ -796,7 +802,7 @@ var ScheduledUpdateText = /*#__PURE__*/_styled(Typography, {
|
|
|
796
802
|
})( {
|
|
797
803
|
name: "1cnls12",
|
|
798
804
|
styles: "min-height:87px",
|
|
799
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAsC+C","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\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: 40px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, }) {\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            buttonProps.title = currentPlan;\r\n            buttonProps.disabled = true;\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 = 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            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"]} */",
|
|
805
|
+
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 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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from './planPriceTier';\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, hasTiersRow, withTrialLeftRow, currentSubscription, selectedTierByFeature, }) {\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(selectedTierByFeature, 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 = 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            hasTiersRow && !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"]} */",
|
|
800
806
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
801
807
|
});
|
|
802
808
|
|
|
@@ -806,7 +812,7 @@ var CancelScheduledUpdateButton = /*#__PURE__*/_styled("button", {
|
|
|
806
812
|
})("background:none;border:none;padding:0;color:", function (_ref6) {
|
|
807
813
|
var theme = _ref6.theme;
|
|
808
814
|
return theme.stigg.palette.text.secondary;
|
|
809
|
-
}, ";text-decoration:underline;cursor:pointer;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAyCkD","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\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: 40px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, }) {\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            buttonProps.title = currentPlan;\r\n            buttonProps.disabled = true;\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 = 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            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"]} */"));
|
|
815
|
+
}, ";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 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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from './planPriceTier';\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, hasTiersRow, withTrialLeftRow, currentSubscription, selectedTierByFeature, }) {\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(selectedTierByFeature, 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 = 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            hasTiersRow && !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"]} */"));
|
|
810
816
|
|
|
811
817
|
var TrialDaysLeft = /*#__PURE__*/_styled(Typography, {
|
|
812
818
|
target: "e199qof91",
|
|
@@ -814,17 +820,17 @@ var TrialDaysLeft = /*#__PURE__*/_styled(Typography, {
|
|
|
814
820
|
})( {
|
|
815
821
|
name: "1etgg0o",
|
|
816
822
|
styles: "margin-top:8px;margin-bottom:17px;min-height:20px",
|
|
817
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAkDyC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\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: 40px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, }) {\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            buttonProps.title = currentPlan;\r\n            buttonProps.disabled = true;\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 = 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            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"]} */",
|
|
823
|
+
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 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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from './planPriceTier';\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, hasTiersRow, withTrialLeftRow, currentSubscription, selectedTierByFeature, }) {\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(selectedTierByFeature, 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 = 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            hasTiersRow && !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"]} */",
|
|
818
824
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
819
825
|
});
|
|
820
826
|
|
|
821
827
|
var ButtonLayout = /*#__PURE__*/_styled("div", {
|
|
822
828
|
target: "e199qof90",
|
|
823
829
|
label: "ButtonLayout"
|
|
824
|
-
})("display:flex;flex-direction:column;margin-top:
|
|
830
|
+
})("display:flex;flex-direction:column;margin-top:4px;align-self:", function (_ref7) {
|
|
825
831
|
var theme = _ref7.theme;
|
|
826
832
|
return flexLayoutMapper(theme.stigg.layout.ctaAlignment);
|
|
827
|
-
}, ";width:100%;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOfferingButton.tsx"],"names":[],"mappings":"AAuDgC","file":"PlanOfferingButton.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport { PricingType } from '@stigg/js-client-sdk';\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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\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: 40px;\n  align-self: ${({ theme }) => flexLayoutMapper(theme.stigg.layout.ctaAlignment)};\n  width: 100%;\n`;\r\nexport function PlanOfferingButton({ isNextPlan, customer, plan, billingPeriod, isCustomerOnTrial, onPlanSelected, paywallLocale, }) {\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            buttonProps.title = currentPlan;\r\n            buttonProps.disabled = true;\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 = 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            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"]} */"));
|
|
833
|
+
}, ";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 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 ClipLoader from 'react-spinners/ClipLoader';\r\nimport { Typography } from '../common/Typography';\r\nimport { getSubscriptionScheduleUpdateTexts } from '../utils/getSubscriptionScheduleUpdateTexts';\r\nimport { isFunction } from 'lodash';\r\nimport { compareSelectedTierToCurrentTier, PriceTierComparison } from './planPriceTier';\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, hasTiersRow, withTrialLeftRow, currentSubscription, selectedTierByFeature, }) {\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(selectedTierByFeature, 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 = 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            hasTiersRow && !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"]} */"));
|
|
828
834
|
|
|
829
835
|
function PlanOfferingButton(_ref8) {
|
|
830
836
|
var isNextPlan = _ref8.isNextPlan,
|
|
@@ -833,7 +839,11 @@ function PlanOfferingButton(_ref8) {
|
|
|
833
839
|
billingPeriod = _ref8.billingPeriod,
|
|
834
840
|
isCustomerOnTrial = _ref8.isCustomerOnTrial,
|
|
835
841
|
onPlanSelected = _ref8.onPlanSelected,
|
|
836
|
-
paywallLocale = _ref8.paywallLocale
|
|
842
|
+
paywallLocale = _ref8.paywallLocale,
|
|
843
|
+
hasTiersRow = _ref8.hasTiersRow,
|
|
844
|
+
withTrialLeftRow = _ref8.withTrialLeftRow,
|
|
845
|
+
currentSubscription = _ref8.currentSubscription,
|
|
846
|
+
selectedTierByFeature = _ref8.selectedTierByFeature;
|
|
837
847
|
var theme = react.useTheme();
|
|
838
848
|
|
|
839
849
|
var _useState = React.useState(false),
|
|
@@ -873,8 +883,24 @@ function PlanOfferingButton(_ref8) {
|
|
|
873
883
|
var isSameBillingPeriod = billingPeriod === plan.currentCustomerPlanBillingPeriod;
|
|
874
884
|
|
|
875
885
|
if (isSameBillingPeriod || plan.pricingType && [Stigg.PricingType.Free, Stigg.PricingType.Custom].includes(plan.pricingType)) {
|
|
876
|
-
|
|
877
|
-
|
|
886
|
+
var planComparison = compareSelectedTierToCurrentTier(selectedTierByFeature, currentSubscription);
|
|
887
|
+
|
|
888
|
+
switch (planComparison) {
|
|
889
|
+
case PriceTierComparison.Lower:
|
|
890
|
+
buttonProps.intentionType = exports.SubscribeIntentionType.CHANGE_UNIT_QUANTITY;
|
|
891
|
+
buttonProps.title = resolvedDowngrade;
|
|
892
|
+
break;
|
|
893
|
+
|
|
894
|
+
case PriceTierComparison.Higher:
|
|
895
|
+
buttonProps.intentionType = exports.SubscribeIntentionType.CHANGE_UNIT_QUANTITY;
|
|
896
|
+
buttonProps.title = resolvedUpgrade;
|
|
897
|
+
break;
|
|
898
|
+
|
|
899
|
+
default:
|
|
900
|
+
buttonProps.title = currentPlan;
|
|
901
|
+
buttonProps.disabled = true;
|
|
902
|
+
break;
|
|
903
|
+
}
|
|
878
904
|
} else {
|
|
879
905
|
buttonProps.title = switchToBillingPeriod(billingPeriod);
|
|
880
906
|
buttonProps.intentionType = exports.SubscribeIntentionType.CHANGE_BILLING_PERIOD;
|
|
@@ -924,7 +950,11 @@ function PlanOfferingButton(_ref8) {
|
|
|
924
950
|
color: theme.stigg.palette.text.disabled,
|
|
925
951
|
loading: true,
|
|
926
952
|
size: 16
|
|
927
|
-
})), React__default.createElement(
|
|
953
|
+
})), hasTiersRow && !withTrialLeftRow ? React__default.createElement("div", {
|
|
954
|
+
style: {
|
|
955
|
+
height: '20px'
|
|
956
|
+
}
|
|
957
|
+
}) : React__default.createElement(TrialDaysLeft, {
|
|
928
958
|
className: "stigg-trial-days-left-text",
|
|
929
959
|
variant: "h6",
|
|
930
960
|
color: "secondary"
|
|
@@ -947,86 +977,308 @@ var SvgMiniSchedule = function SvgMiniSchedule(props) {
|
|
|
947
977
|
})));
|
|
948
978
|
};
|
|
949
979
|
|
|
950
|
-
|
|
951
|
-
var
|
|
980
|
+
var currencyPriceFormatter = function currencyPriceFormatter(_ref) {
|
|
981
|
+
var amount = _ref.amount,
|
|
982
|
+
_ref$currency = _ref.currency,
|
|
983
|
+
currency = _ref$currency === void 0 ? Stigg.Currency.Usd : _ref$currency,
|
|
984
|
+
locale = _ref.locale,
|
|
985
|
+
_ref$maximumFractionD = _ref.maximumFractionDigits,
|
|
986
|
+
maximumFractionDigits = _ref$maximumFractionD === void 0 ? 5 : _ref$maximumFractionD;
|
|
987
|
+
var currencyString = currency.toString();
|
|
988
|
+
var currencySymbol = getSymbolFromCurrency(currencyString);
|
|
989
|
+
var formattedPrice = new Intl.NumberFormat(locale, _extends({
|
|
990
|
+
maximumFractionDigits: maximumFractionDigits,
|
|
991
|
+
minimumFractionDigits: 0,
|
|
992
|
+
style: 'currency',
|
|
993
|
+
currency: currencyString
|
|
994
|
+
}, currencySymbol ? {
|
|
995
|
+
currencyDisplay: 'code'
|
|
996
|
+
} : {})).format(amount || 0);
|
|
952
997
|
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
})("position:relative;background-color:", function (_ref) {
|
|
957
|
-
var theme = _ref.theme,
|
|
958
|
-
$isCurrentPlan = _ref.$isCurrentPlan;
|
|
959
|
-
return $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper;
|
|
960
|
-
}, ";border:", function (_ref2) {
|
|
961
|
-
var theme = _ref2.theme,
|
|
962
|
-
$isHighlighted = _ref2.$isHighlighted;
|
|
963
|
-
return $isHighlighted ? "3px solid " + theme.stigg.palette.primary : "1px solid " + theme.stigg.palette.outlinedBorder;
|
|
964
|
-
}, ";border-radius:10px;padding:", function (_ref3) {
|
|
965
|
-
var theme = _ref3.theme;
|
|
966
|
-
return theme.stigg.layout.planPadding;
|
|
967
|
-
}, ";display:flex;min-width:", function (_ref4) {
|
|
968
|
-
var theme = _ref4.theme;
|
|
969
|
-
return theme.stigg.layout.planMinWidth;
|
|
970
|
-
}, ";max-width:", function (_ref5) {
|
|
971
|
-
var theme = _ref5.theme;
|
|
972
|
-
return theme.stigg.layout.planMaxWidth;
|
|
973
|
-
}, ";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":"AAWyC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */"));
|
|
998
|
+
if (currencySymbol) {
|
|
999
|
+
formattedPrice = formattedPrice.replace(currencyString, currencySymbol);
|
|
1000
|
+
} // remove space between currency symbol and price
|
|
974
1001
|
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
}
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAyBsC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */",
|
|
982
|
-
|
|
983
|
-
|
|
1002
|
+
|
|
1003
|
+
formattedPrice = formattedPrice.replace(/\s/g, '');
|
|
1004
|
+
return formattedPrice;
|
|
1005
|
+
};
|
|
1006
|
+
|
|
1007
|
+
function getPaidPriceText(_ref) {
|
|
1008
|
+
var planPrices = _ref.planPrices,
|
|
1009
|
+
paywallCalculatedPrice = _ref.paywallCalculatedPrice,
|
|
1010
|
+
selectedBillingPeriod = _ref.selectedBillingPeriod,
|
|
1011
|
+
locale = _ref.locale,
|
|
1012
|
+
shouldShowMonthlyPriceAmount = _ref.shouldShowMonthlyPriceAmount,
|
|
1013
|
+
selectedTierByFeature = _ref.selectedTierByFeature;
|
|
1014
|
+
|
|
1015
|
+
var _ref2 = paywallCalculatedPrice || planPrices[0],
|
|
1016
|
+
amount = _ref2.amount,
|
|
1017
|
+
currency = _ref2.currency;
|
|
1018
|
+
|
|
1019
|
+
var priceAmount = amount || 0;
|
|
1020
|
+
var isSinglePrice = planPrices.length === 1;
|
|
1021
|
+
var priceNumber = selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? priceAmount / 12 : priceAmount;
|
|
1022
|
+
var tiers;
|
|
1023
|
+
var tierUnits;
|
|
1024
|
+
var unit = shouldShowMonthlyPriceAmount ? '/ month' : '/ year';
|
|
1025
|
+
|
|
1026
|
+
for (var _iterator = _createForOfIteratorHelperLoose(planPrices), _step; !(_step = _iterator()).done;) {
|
|
1027
|
+
var _price = _step.value;
|
|
1028
|
+
|
|
1029
|
+
if (_price.isTieredPrice) {
|
|
1030
|
+
var currentTier = _price.tiers[0];
|
|
1031
|
+
|
|
1032
|
+
if (selectedTierByFeature[_price.feature.featureId]) {
|
|
1033
|
+
currentTier = selectedTierByFeature[_price.feature.featureId] || currentTier;
|
|
1034
|
+
tiers = _price.tiers;
|
|
1035
|
+
tierUnits = _price.feature.unitsPlural || '';
|
|
1036
|
+
}
|
|
1037
|
+
|
|
1038
|
+
priceNumber += calculateTierPrice(_price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
1039
|
+
}
|
|
1040
|
+
}
|
|
1041
|
+
|
|
1042
|
+
if (isSinglePrice) {
|
|
1043
|
+
var _price$feature;
|
|
1044
|
+
|
|
1045
|
+
var price = planPrices[0];
|
|
1046
|
+
var featureUnit = ((_price$feature = price.feature) == null ? void 0 : _price$feature.units) || '';
|
|
1047
|
+
|
|
1048
|
+
if (price.pricingModel === Stigg.BillingModel.PerUnit && !price.isTieredPrice) {
|
|
1049
|
+
unit = shouldShowMonthlyPriceAmount ? "per " + featureUnit + " / month" : "per " + featureUnit + " / year";
|
|
1050
|
+
} else if (price.pricingModel === Stigg.BillingModel.UsageBased) {
|
|
1051
|
+
unit = "per " + featureUnit;
|
|
1052
|
+
}
|
|
1053
|
+
}
|
|
1054
|
+
|
|
1055
|
+
return {
|
|
1056
|
+
price: currencyPriceFormatter({
|
|
1057
|
+
amount: priceNumber,
|
|
1058
|
+
currency: currency,
|
|
1059
|
+
locale: locale
|
|
1060
|
+
}),
|
|
1061
|
+
unit: unit,
|
|
1062
|
+
tiers: tiers,
|
|
1063
|
+
tierUnits: tierUnits
|
|
1064
|
+
};
|
|
1065
|
+
}
|
|
1066
|
+
|
|
1067
|
+
function getPlanPrice(plan, billingPeriod, paywallLocale, locale, shouldShowMonthlyPriceAmount, selectedTierByFeature) {
|
|
1068
|
+
switch (plan.pricingType) {
|
|
1069
|
+
case Stigg.PricingType.Free:
|
|
1070
|
+
if (typeof paywallLocale.price.free === 'function') {
|
|
1071
|
+
return paywallLocale.price.free(plan.paywallCurrency);
|
|
1072
|
+
}
|
|
1073
|
+
|
|
1074
|
+
return paywallLocale.price.free;
|
|
1075
|
+
|
|
1076
|
+
case Stigg.PricingType.Custom:
|
|
1077
|
+
return {
|
|
1078
|
+
price: paywallLocale.price.custom
|
|
1079
|
+
};
|
|
1080
|
+
|
|
1081
|
+
case Stigg.PricingType.Paid:
|
|
1082
|
+
{
|
|
1083
|
+
var _plan$paywallCalculat;
|
|
1084
|
+
|
|
1085
|
+
var planPrices = plan.pricePoints.filter(function (pricePoint) {
|
|
1086
|
+
return pricePoint.billingPeriod === billingPeriod;
|
|
1087
|
+
});
|
|
1088
|
+
var paywallCalculatedPrice = (_plan$paywallCalculat = plan.paywallCalculatedPricePoints) == null ? void 0 : _plan$paywallCalculat.find(function (pricePoint) {
|
|
1089
|
+
return pricePoint.billingPeriod === billingPeriod;
|
|
1090
|
+
});
|
|
1091
|
+
|
|
1092
|
+
if (!(planPrices != null && planPrices.length) && !paywallCalculatedPrice) {
|
|
1093
|
+
return {
|
|
1094
|
+
price: paywallLocale.price.priceNotSet
|
|
1095
|
+
};
|
|
1096
|
+
}
|
|
1097
|
+
|
|
1098
|
+
var paidParams = {
|
|
1099
|
+
planPrices: planPrices,
|
|
1100
|
+
paywallCalculatedPrice: paywallCalculatedPrice,
|
|
1101
|
+
selectedBillingPeriod: billingPeriod,
|
|
1102
|
+
selectedTierByFeature: selectedTierByFeature || {}
|
|
1103
|
+
};
|
|
1104
|
+
return paywallLocale.price.paid ? paywallLocale.price.paid(_extends({}, paidParams, {
|
|
1105
|
+
plan: plan
|
|
1106
|
+
})) : getPaidPriceText(_extends({}, paidParams, {
|
|
1107
|
+
locale: locale,
|
|
1108
|
+
shouldShowMonthlyPriceAmount: shouldShowMonthlyPriceAmount
|
|
1109
|
+
}));
|
|
1110
|
+
}
|
|
1111
|
+
|
|
1112
|
+
default:
|
|
1113
|
+
return {
|
|
1114
|
+
price: ''
|
|
1115
|
+
};
|
|
1116
|
+
}
|
|
1117
|
+
}
|
|
1118
|
+
|
|
1119
|
+
var TierSelect = /*#__PURE__*/_styled(material.Select, {
|
|
1120
|
+
target: "exuepap1",
|
|
1121
|
+
label: "TierSelect"
|
|
1122
|
+
})("border-radius:10px;&:hover .MuiOutlinedInput-notchedOutline{border-color:", function (_ref) {
|
|
1123
|
+
var theme = _ref.theme;
|
|
1124
|
+
return theme.stigg.palette.outlinedBorder;
|
|
1125
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzTGF5b3V0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLa0MiLCJmaWxlIjoiVGllcnNMYXlvdXQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUl0ZW0sIE91dGxpbmVkSW5wdXQsIFNlbGVjdCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdsb2Rhc2gnO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmNvbnN0IFRpZXJTZWxlY3QgPSBzdHlsZWQoU2VsZWN0KSBgXG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG5cbiAgJjpob3ZlciAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9O1xuICB9XG5gO1xyXG5jb25zdCBUaWVySW5wdXQgPSBzdHlsZWQoT3V0bGluZWRJbnB1dCkgYFxuICAmIC5NdWlJbnB1dEJhc2UtaW5wdXQge1xuICAgIHBhZGRpbmc6IDdweCAxMnB4O1xuICB9XG5cbiAgJi5NdWktZm9jdXNlZCAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX0gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRpZXJzTGF5b3V0KHsgcGxhbiwgdGllcnMsIHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyLCBoYW5kbGVUaWVyQ2hhbmdlLCB9KSB7XHJcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZXZlbnQsIF8pID0+IHtcclxuICAgICAgICBoYW5kbGVUaWVyQ2hhbmdlKHRpZXJzLmZpbmQodGllciA9PiB0aWVyLnVwVG8udG9TdHJpbmcoKSA9PT0gZXZlbnQudGFyZ2V0LnZhbHVlKSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRpZXItc2VsZWN0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ2cHgnIH0gfSwgdGllcnMgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChUaWVyU2VsZWN0LCB7IGxhYmVsSWQ6IFwiZGVtby1zaW1wbGUtc2VsZWN0LWxhYmVsXCIsIGlkOiBgc2VsZWN0XyR7cGxhbi5pZH1gLCB2YWx1ZTogc2VsZWN0ZWRUaWVyID8gc2VsZWN0ZWRUaWVyLnVwVG8udG9TdHJpbmcoKSA6IHRpZXJzWzBdLnVwVG8udG9TdHJpbmcoKSwgZnVsbFdpZHRoOiB0cnVlLCBvbkNoYW5nZTogaGFuZGxlQ2hhbmdlLCBpbnB1dDogUmVhY3QuY3JlYXRlRWxlbWVudChUaWVySW5wdXQsIG51bGwpLCBNZW51UHJvcHM6IHtcclxuICAgICAgICAgICAgTWVudUxpc3RQcm9wczogeyBkaXNhYmxlUGFkZGluZzogdHJ1ZSB9LFxyXG4gICAgICAgICAgICBQYXBlclByb3BzOiB7XHJcbiAgICAgICAgICAgICAgICBzeDogeyBtYXJnaW5Ub3A6ICc0cHgnLCBib3JkZXJSYWRpdXM6ICcxMHB4JyB9LFxyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgIH0gfSwgbWFwKHRpZXJzLCAodGllcikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTWVudUl0ZW0sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRpZXItbWVudS1pdGVtLXRleHRcIiwga2V5OiB0aWVyLnVwVG8sIHZhbHVlOiB0aWVyLnVwVG8udG9TdHJpbmcoKSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInByaW1hcnlcIiB9LFxyXG4gICAgICAgICAgICB0aWVyLnVwVG8sXHJcbiAgICAgICAgICAgIFwiIFwiLFxyXG4gICAgICAgICAgICB0aWVyVW5pdHMpKSkpKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCBudWxsKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UaWVyc0xheW91dC5qcy5tYXAiXX0= */"));
|
|
1126
|
+
|
|
1127
|
+
var TierInput = /*#__PURE__*/_styled(material.OutlinedInput, {
|
|
1128
|
+
target: "exuepap0",
|
|
1129
|
+
label: "TierInput"
|
|
1130
|
+
})("& .MuiInputBase-input{padding:7px 12px;}&.Mui-focused .MuiOutlinedInput-notchedOutline{border-color:", function (_ref2) {
|
|
1131
|
+
var theme = _ref2.theme;
|
|
1132
|
+
return theme.stigg.palette.primary;
|
|
1133
|
+
}, "!important;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzTGF5b3V0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZd0MiLCJmaWxlIjoiVGllcnNMYXlvdXQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUl0ZW0sIE91dGxpbmVkSW5wdXQsIFNlbGVjdCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdsb2Rhc2gnO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmNvbnN0IFRpZXJTZWxlY3QgPSBzdHlsZWQoU2VsZWN0KSBgXG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG5cbiAgJjpob3ZlciAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9O1xuICB9XG5gO1xyXG5jb25zdCBUaWVySW5wdXQgPSBzdHlsZWQoT3V0bGluZWRJbnB1dCkgYFxuICAmIC5NdWlJbnB1dEJhc2UtaW5wdXQge1xuICAgIHBhZGRpbmc6IDdweCAxMnB4O1xuICB9XG5cbiAgJi5NdWktZm9jdXNlZCAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX0gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRpZXJzTGF5b3V0KHsgcGxhbiwgdGllcnMsIHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyLCBoYW5kbGVUaWVyQ2hhbmdlLCB9KSB7XHJcbiAgICBjb25zdCBoYW5kbGVDaGFuZ2UgPSAoZXZlbnQsIF8pID0+IHtcclxuICAgICAgICBoYW5kbGVUaWVyQ2hhbmdlKHRpZXJzLmZpbmQodGllciA9PiB0aWVyLnVwVG8udG9TdHJpbmcoKSA9PT0gZXZlbnQudGFyZ2V0LnZhbHVlKSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRpZXItc2VsZWN0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ2cHgnIH0gfSwgdGllcnMgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChUaWVyU2VsZWN0LCB7IGxhYmVsSWQ6IFwiZGVtby1zaW1wbGUtc2VsZWN0LWxhYmVsXCIsIGlkOiBgc2VsZWN0XyR7cGxhbi5pZH1gLCB2YWx1ZTogc2VsZWN0ZWRUaWVyID8gc2VsZWN0ZWRUaWVyLnVwVG8udG9TdHJpbmcoKSA6IHRpZXJzWzBdLnVwVG8udG9TdHJpbmcoKSwgZnVsbFdpZHRoOiB0cnVlLCBvbkNoYW5nZTogaGFuZGxlQ2hhbmdlLCBpbnB1dDogUmVhY3QuY3JlYXRlRWxlbWVudChUaWVySW5wdXQsIG51bGwpLCBNZW51UHJvcHM6IHtcclxuICAgICAgICAgICAgTWVudUxpc3RQcm9wczogeyBkaXNhYmxlUGFkZGluZzogdHJ1ZSB9LFxyXG4gICAgICAgICAgICBQYXBlclByb3BzOiB7XHJcbiAgICAgICAgICAgICAgICBzeDogeyBtYXJnaW5Ub3A6ICc0cHgnLCBib3JkZXJSYWRpdXM6ICcxMHB4JyB9LFxyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgIH0gfSwgbWFwKHRpZXJzLCAodGllcikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTWVudUl0ZW0sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRpZXItbWVudS1pdGVtLXRleHRcIiwga2V5OiB0aWVyLnVwVG8sIHZhbHVlOiB0aWVyLnVwVG8udG9TdHJpbmcoKSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInByaW1hcnlcIiB9LFxyXG4gICAgICAgICAgICB0aWVyLnVwVG8sXHJcbiAgICAgICAgICAgIFwiIFwiLFxyXG4gICAgICAgICAgICB0aWVyVW5pdHMpKSkpKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCBudWxsKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UaWVyc0xheW91dC5qcy5tYXAiXX0= */"));
|
|
1134
|
+
|
|
1135
|
+
function TiersLayout(_ref3) {
|
|
1136
|
+
var plan = _ref3.plan,
|
|
1137
|
+
tiers = _ref3.tiers,
|
|
1138
|
+
tierUnits = _ref3.tierUnits,
|
|
1139
|
+
selectedTier = _ref3.selectedTier,
|
|
1140
|
+
handleTierChange = _ref3.handleTierChange;
|
|
1141
|
+
|
|
1142
|
+
var handleChange = function handleChange(event, _) {
|
|
1143
|
+
handleTierChange(tiers.find(function (tier) {
|
|
1144
|
+
return tier.upTo.toString() === event.target.value;
|
|
1145
|
+
}));
|
|
1146
|
+
};
|
|
1147
|
+
|
|
1148
|
+
return React__default.createElement(Typography, {
|
|
1149
|
+
className: "stigg-price-tier-select",
|
|
1150
|
+
style: {
|
|
1151
|
+
minHeight: '46px'
|
|
1152
|
+
}
|
|
1153
|
+
}, tiers ? React__default.createElement(TierSelect, {
|
|
1154
|
+
labelId: "demo-simple-select-label",
|
|
1155
|
+
id: "select_" + plan.id,
|
|
1156
|
+
value: selectedTier ? selectedTier.upTo.toString() : tiers[0].upTo.toString(),
|
|
1157
|
+
fullWidth: true,
|
|
1158
|
+
onChange: handleChange,
|
|
1159
|
+
input: React__default.createElement(TierInput, null),
|
|
1160
|
+
MenuProps: {
|
|
1161
|
+
MenuListProps: {
|
|
1162
|
+
disablePadding: true
|
|
1163
|
+
},
|
|
1164
|
+
PaperProps: {
|
|
1165
|
+
sx: {
|
|
1166
|
+
marginTop: '4px',
|
|
1167
|
+
borderRadius: '10px'
|
|
1168
|
+
}
|
|
1169
|
+
}
|
|
1170
|
+
}
|
|
1171
|
+
}, lodash.map(tiers, function (tier) {
|
|
1172
|
+
return React__default.createElement(material.MenuItem, {
|
|
1173
|
+
className: "stigg-price-tier-menu-item-text",
|
|
1174
|
+
key: tier.upTo,
|
|
1175
|
+
value: tier.upTo.toString()
|
|
1176
|
+
}, React__default.createElement(Typography, {
|
|
1177
|
+
variant: "body1",
|
|
1178
|
+
color: "primary"
|
|
1179
|
+
}, tier.upTo, " ", tierUnits));
|
|
1180
|
+
})) : React__default.createElement("div", null));
|
|
1181
|
+
}
|
|
1182
|
+
|
|
1183
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$3() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
1184
|
+
var EMPTY_CHAR = '';
|
|
984
1185
|
|
|
985
1186
|
var PlanPriceContainer = /*#__PURE__*/_styled(Typography, {
|
|
986
|
-
target: "
|
|
1187
|
+
target: "e1gsqbi12",
|
|
987
1188
|
label: "PlanPriceContainer"
|
|
988
1189
|
})( {
|
|
989
|
-
name: "
|
|
990
|
-
styles: "word-break:break-word",
|
|
991
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA4B8C","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */",
|
|
1190
|
+
name: "bfvx8c",
|
|
1191
|
+
styles: "word-break:break-word;width:100%",
|
|
1192
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTThDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc0xheW91dCB9IGZyb20gJy4vVGllcnNMYXlvdXQnO1xyXG5jb25zdCBFTVBUWV9DSEFSID0gJ+KAjic7XHJcbmNvbnN0IFBsYW5QcmljZUNvbnRhaW5lciA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdvcmQtYnJlYWs6IGJyZWFrLXdvcmQ7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuY29uc3QgVW5pdFNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuYDtcclxuY29uc3QgUHJpY2VTcGFuID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd2hpdGUtc3BhY2U6IG5vcm1hbDtcbiAgbWluLWhlaWdodDogMzlweDtcbmA7XHJcbmZ1bmN0aW9uIFByaWNlQmlsbGluZ1BlcmlvZCh7IHBsYW4sIGJpbGxpbmdQZXJpb2QsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCk7XHJcbiAgICBsZXQgY29udGVudCA9IEVNUFRZX0NIQVI7XHJcbiAgICBpZiAoaGFzUHJpY2UgJiYgaGFzTW9udGhseVByaWNlICYmIGhhc0FubnVhbGx5UHJpY2UpIHtcclxuICAgICAgICBjb250ZW50ID0gYCwgYmlsbGVkICR7YmlsbGluZ1BlcmlvZC50b0xvd2VyQ2FzZSgpfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNvbnRlbnQpKTtcclxufVxyXG5leHBvcnQgY29uc3QgUGxhblByaWNlID0gKHsgc2hvd1N0YXJ0aW5nQXQsIHdpdGhVbml0UHJpY2VSb3csIHdpdGhTdGFydGluZ0F0Um93LCB3aXRoVGllcnNSb3csIHNlbGVjdGVkVGllckJ5RmVhdHVyZSwgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBwcmljZSwgdW5pdCwgdGllcnMsIHRpZXJVbml0cyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRUaWVyQnlGZWF0dXJlXSk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHBsYW5QcmljZSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZS5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kICYmIHBsYW5QcmljZS5pc1RpZXJlZFByaWNlO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCBmZWF0dXJlSWQgPSB0aWVyZWRQcmljZSA/IHRpZXJlZFByaWNlLmZlYXR1cmUuZmVhdHVyZUlkIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgY29uc3QgdXBkYXRlZFRpZXJCeUZlYXR1cmUgPSB7fTtcclxuICAgICAgICB1cGRhdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdID0gdGllcjtcclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUodXBkYXRlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgfTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKHRpZXJzKSB7XHJcbiAgICAgICAgICAgIGhhbmRsZVRpZXJDaGFuZ2Uoc2VsZWN0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0pO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuUHJpY2VDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRleHRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIHdpdGhTdGFydGluZ0F0Um93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3R5bGU6IHsgbWluSGVpZ2h0OiAnMjBweCcgfSwgY2xhc3NOYW1lOiBcInN0aWdnLXN0YXJ0aW5nLWF0LXRleHRcIiwgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBzaG93U3RhcnRpbmdBdCA/IHBheXdhbGxMb2NhbGUucHJpY2Uuc3RhcnRpbmdBdENhcHRpb24gOiBFTVBUWV9DSEFSKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VTcGFuLCB7IHZhcmlhbnQ6IFwiaDFcIiB9LCBwcmljZSksXHJcbiAgICAgICAgICAgIHdpdGhVbml0UHJpY2VSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdW5pdC1hbmQtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0OHB4JyB9IH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFVuaXRTcGFuLCB7IHNwYW46IHRydWUsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdW5pdCksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlQmlsbGluZ1BlcmlvZCwgeyBwbGFuOiBwbGFuLCBiaWxsaW5nUGVyaW9kOiBiaWxsaW5nUGVyaW9kLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSB9KSkpLFxyXG4gICAgICAgICAgICB3aXRoVGllcnNSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNMYXlvdXQsIHsgcGxhbjogcGxhbiwgdGllcnM6IHRpZXJzLCB0aWVyVW5pdHM6IHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyOiBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2U6IGhhbmRsZVRpZXJDaGFuZ2UgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
|
|
992
1193
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
993
1194
|
});
|
|
994
1195
|
|
|
995
1196
|
var UnitSpan = /*#__PURE__*/_styled(Typography, {
|
|
996
|
-
target: "
|
|
1197
|
+
target: "e1gsqbi11",
|
|
997
1198
|
label: "UnitSpan"
|
|
998
1199
|
})( {
|
|
999
1200
|
name: "1bmnxg7",
|
|
1000
1201
|
styles: "white-space:nowrap",
|
|
1001
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA+BoC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */",
|
|
1202
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc0xheW91dCB9IGZyb20gJy4vVGllcnNMYXlvdXQnO1xyXG5jb25zdCBFTVBUWV9DSEFSID0gJ+KAjic7XHJcbmNvbnN0IFBsYW5QcmljZUNvbnRhaW5lciA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdvcmQtYnJlYWs6IGJyZWFrLXdvcmQ7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuY29uc3QgVW5pdFNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuYDtcclxuY29uc3QgUHJpY2VTcGFuID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd2hpdGUtc3BhY2U6IG5vcm1hbDtcbiAgbWluLWhlaWdodDogMzlweDtcbmA7XHJcbmZ1bmN0aW9uIFByaWNlQmlsbGluZ1BlcmlvZCh7IHBsYW4sIGJpbGxpbmdQZXJpb2QsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCk7XHJcbiAgICBsZXQgY29udGVudCA9IEVNUFRZX0NIQVI7XHJcbiAgICBpZiAoaGFzUHJpY2UgJiYgaGFzTW9udGhseVByaWNlICYmIGhhc0FubnVhbGx5UHJpY2UpIHtcclxuICAgICAgICBjb250ZW50ID0gYCwgYmlsbGVkICR7YmlsbGluZ1BlcmlvZC50b0xvd2VyQ2FzZSgpfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNvbnRlbnQpKTtcclxufVxyXG5leHBvcnQgY29uc3QgUGxhblByaWNlID0gKHsgc2hvd1N0YXJ0aW5nQXQsIHdpdGhVbml0UHJpY2VSb3csIHdpdGhTdGFydGluZ0F0Um93LCB3aXRoVGllcnNSb3csIHNlbGVjdGVkVGllckJ5RmVhdHVyZSwgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBwcmljZSwgdW5pdCwgdGllcnMsIHRpZXJVbml0cyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRUaWVyQnlGZWF0dXJlXSk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHBsYW5QcmljZSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZS5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kICYmIHBsYW5QcmljZS5pc1RpZXJlZFByaWNlO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCBmZWF0dXJlSWQgPSB0aWVyZWRQcmljZSA/IHRpZXJlZFByaWNlLmZlYXR1cmUuZmVhdHVyZUlkIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgY29uc3QgdXBkYXRlZFRpZXJCeUZlYXR1cmUgPSB7fTtcclxuICAgICAgICB1cGRhdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdID0gdGllcjtcclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUodXBkYXRlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgfTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKHRpZXJzKSB7XHJcbiAgICAgICAgICAgIGhhbmRsZVRpZXJDaGFuZ2Uoc2VsZWN0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0pO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuUHJpY2VDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRleHRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIHdpdGhTdGFydGluZ0F0Um93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3R5bGU6IHsgbWluSGVpZ2h0OiAnMjBweCcgfSwgY2xhc3NOYW1lOiBcInN0aWdnLXN0YXJ0aW5nLWF0LXRleHRcIiwgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBzaG93U3RhcnRpbmdBdCA/IHBheXdhbGxMb2NhbGUucHJpY2Uuc3RhcnRpbmdBdENhcHRpb24gOiBFTVBUWV9DSEFSKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VTcGFuLCB7IHZhcmlhbnQ6IFwiaDFcIiB9LCBwcmljZSksXHJcbiAgICAgICAgICAgIHdpdGhVbml0UHJpY2VSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdW5pdC1hbmQtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0OHB4JyB9IH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFVuaXRTcGFuLCB7IHNwYW46IHRydWUsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdW5pdCksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlQmlsbGluZ1BlcmlvZCwgeyBwbGFuOiBwbGFuLCBiaWxsaW5nUGVyaW9kOiBiaWxsaW5nUGVyaW9kLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSB9KSkpLFxyXG4gICAgICAgICAgICB3aXRoVGllcnNSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNMYXlvdXQsIHsgcGxhbjogcGxhbiwgdGllcnM6IHRpZXJzLCB0aWVyVW5pdHM6IHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyOiBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2U6IGhhbmRsZVRpZXJDaGFuZ2UgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
|
|
1002
1203
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
1003
1204
|
});
|
|
1004
1205
|
|
|
1005
1206
|
var PriceSpan = /*#__PURE__*/_styled(Typography, {
|
|
1006
|
-
target: "
|
|
1207
|
+
target: "e1gsqbi10",
|
|
1007
1208
|
label: "PriceSpan"
|
|
1008
1209
|
})( {
|
|
1009
1210
|
name: "nurf5y",
|
|
1010
1211
|
styles: "white-space:normal;min-height:39px",
|
|
1011
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAkCqC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */",
|
|
1212
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXFDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc0xheW91dCB9IGZyb20gJy4vVGllcnNMYXlvdXQnO1xyXG5jb25zdCBFTVBUWV9DSEFSID0gJ+KAjic7XHJcbmNvbnN0IFBsYW5QcmljZUNvbnRhaW5lciA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdvcmQtYnJlYWs6IGJyZWFrLXdvcmQ7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuY29uc3QgVW5pdFNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuYDtcclxuY29uc3QgUHJpY2VTcGFuID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd2hpdGUtc3BhY2U6IG5vcm1hbDtcbiAgbWluLWhlaWdodDogMzlweDtcbmA7XHJcbmZ1bmN0aW9uIFByaWNlQmlsbGluZ1BlcmlvZCh7IHBsYW4sIGJpbGxpbmdQZXJpb2QsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCk7XHJcbiAgICBsZXQgY29udGVudCA9IEVNUFRZX0NIQVI7XHJcbiAgICBpZiAoaGFzUHJpY2UgJiYgaGFzTW9udGhseVByaWNlICYmIGhhc0FubnVhbGx5UHJpY2UpIHtcclxuICAgICAgICBjb250ZW50ID0gYCwgYmlsbGVkICR7YmlsbGluZ1BlcmlvZC50b0xvd2VyQ2FzZSgpfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNvbnRlbnQpKTtcclxufVxyXG5leHBvcnQgY29uc3QgUGxhblByaWNlID0gKHsgc2hvd1N0YXJ0aW5nQXQsIHdpdGhVbml0UHJpY2VSb3csIHdpdGhTdGFydGluZ0F0Um93LCB3aXRoVGllcnNSb3csIHNlbGVjdGVkVGllckJ5RmVhdHVyZSwgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBwcmljZSwgdW5pdCwgdGllcnMsIHRpZXJVbml0cyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRUaWVyQnlGZWF0dXJlXSk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHBsYW5QcmljZSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZS5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kICYmIHBsYW5QcmljZS5pc1RpZXJlZFByaWNlO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCBmZWF0dXJlSWQgPSB0aWVyZWRQcmljZSA/IHRpZXJlZFByaWNlLmZlYXR1cmUuZmVhdHVyZUlkIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgY29uc3QgdXBkYXRlZFRpZXJCeUZlYXR1cmUgPSB7fTtcclxuICAgICAgICB1cGRhdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdID0gdGllcjtcclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUodXBkYXRlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgfTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKHRpZXJzKSB7XHJcbiAgICAgICAgICAgIGhhbmRsZVRpZXJDaGFuZ2Uoc2VsZWN0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0pO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuUHJpY2VDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRleHRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIHdpdGhTdGFydGluZ0F0Um93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3R5bGU6IHsgbWluSGVpZ2h0OiAnMjBweCcgfSwgY2xhc3NOYW1lOiBcInN0aWdnLXN0YXJ0aW5nLWF0LXRleHRcIiwgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBzaG93U3RhcnRpbmdBdCA/IHBheXdhbGxMb2NhbGUucHJpY2Uuc3RhcnRpbmdBdENhcHRpb24gOiBFTVBUWV9DSEFSKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VTcGFuLCB7IHZhcmlhbnQ6IFwiaDFcIiB9LCBwcmljZSksXHJcbiAgICAgICAgICAgIHdpdGhVbml0UHJpY2VSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdW5pdC1hbmQtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0OHB4JyB9IH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFVuaXRTcGFuLCB7IHNwYW46IHRydWUsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdW5pdCksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlQmlsbGluZ1BlcmlvZCwgeyBwbGFuOiBwbGFuLCBiaWxsaW5nUGVyaW9kOiBiaWxsaW5nUGVyaW9kLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSB9KSkpLFxyXG4gICAgICAgICAgICB3aXRoVGllcnNSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNMYXlvdXQsIHsgcGxhbjogcGxhbiwgdGllcnM6IHRpZXJzLCB0aWVyVW5pdHM6IHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyOiBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2U6IGhhbmRsZVRpZXJDaGFuZ2UgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
|
|
1012
1213
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
1013
1214
|
});
|
|
1014
1215
|
|
|
1015
|
-
function
|
|
1016
|
-
var
|
|
1017
|
-
|
|
1018
|
-
|
|
1019
|
-
|
|
1020
|
-
|
|
1021
|
-
|
|
1022
|
-
|
|
1023
|
-
|
|
1024
|
-
|
|
1025
|
-
|
|
1026
|
-
|
|
1216
|
+
function PriceBillingPeriod(_ref) {
|
|
1217
|
+
var plan = _ref.plan,
|
|
1218
|
+
billingPeriod = _ref.billingPeriod,
|
|
1219
|
+
hasMonthlyPrice = _ref.hasMonthlyPrice,
|
|
1220
|
+
hasAnnuallyPrice = _ref.hasAnnuallyPrice;
|
|
1221
|
+
var hasPrice = plan.pricePoints.find(function (pricePoint) {
|
|
1222
|
+
return pricePoint.billingPeriod === billingPeriod;
|
|
1223
|
+
});
|
|
1224
|
+
var content = EMPTY_CHAR;
|
|
1225
|
+
|
|
1226
|
+
if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {
|
|
1227
|
+
content = ", billed " + billingPeriod.toLowerCase();
|
|
1228
|
+
}
|
|
1229
|
+
|
|
1230
|
+
return React__default.createElement(Typography, {
|
|
1231
|
+
span: true,
|
|
1232
|
+
className: "stigg-price-billing-period-text",
|
|
1233
|
+
variant: "h6",
|
|
1234
|
+
color: "secondary"
|
|
1235
|
+
}, content);
|
|
1236
|
+
}
|
|
1237
|
+
|
|
1238
|
+
var PlanPrice = function PlanPrice(_ref2) {
|
|
1239
|
+
var showStartingAt = _ref2.showStartingAt,
|
|
1240
|
+
withUnitPriceRow = _ref2.withUnitPriceRow,
|
|
1241
|
+
withStartingAtRow = _ref2.withStartingAtRow,
|
|
1242
|
+
withTiersRow = _ref2.withTiersRow,
|
|
1243
|
+
selectedTierByFeature = _ref2.selectedTierByFeature,
|
|
1244
|
+
setSelectedTierByFeature = _ref2.setSelectedTierByFeature,
|
|
1245
|
+
plan = _ref2.plan,
|
|
1246
|
+
billingPeriod = _ref2.billingPeriod,
|
|
1247
|
+
paywallLocale = _ref2.paywallLocale,
|
|
1248
|
+
locale = _ref2.locale,
|
|
1249
|
+
hasMonthlyPrice = _ref2.hasMonthlyPrice,
|
|
1250
|
+
hasAnnuallyPrice = _ref2.hasAnnuallyPrice;
|
|
1251
|
+
|
|
1252
|
+
var _getPlanPrice = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, selectedTierByFeature),
|
|
1027
1253
|
price = _getPlanPrice.price,
|
|
1028
|
-
unit = _getPlanPrice.unit
|
|
1254
|
+
unit = _getPlanPrice.unit,
|
|
1255
|
+
tiers = _getPlanPrice.tiers,
|
|
1256
|
+
tierUnits = _getPlanPrice.tierUnits;
|
|
1257
|
+
|
|
1258
|
+
var _useState = React.useState(),
|
|
1259
|
+
selectedTier = _useState[0],
|
|
1260
|
+
setSelectedTier = _useState[1];
|
|
1261
|
+
|
|
1262
|
+
React.useEffect(function () {
|
|
1263
|
+
setSelectedTier(selectedTierByFeature[featureId]);
|
|
1264
|
+
}, [selectedTierByFeature]); // We currently only support prices with one tier - so we select the first one
|
|
1029
1265
|
|
|
1266
|
+
var tieredPrice = plan.pricePoints.find(function (planPrice) {
|
|
1267
|
+
return planPrice.billingPeriod === billingPeriod && planPrice.isTieredPrice;
|
|
1268
|
+
});
|
|
1269
|
+
var featureId = tieredPrice ? tieredPrice.feature.featureId : undefined;
|
|
1270
|
+
|
|
1271
|
+
var handleTierChange = function handleTierChange(tier) {
|
|
1272
|
+
var updatedTierByFeature = {};
|
|
1273
|
+
updatedTierByFeature[featureId] = tier;
|
|
1274
|
+
setSelectedTierByFeature(updatedTierByFeature);
|
|
1275
|
+
};
|
|
1276
|
+
|
|
1277
|
+
React.useEffect(function () {
|
|
1278
|
+
if (tiers) {
|
|
1279
|
+
handleTierChange(selectedTierByFeature[featureId]);
|
|
1280
|
+
}
|
|
1281
|
+
}, []);
|
|
1030
1282
|
return React__default.createElement(PlanPriceContainer, {
|
|
1031
1283
|
className: "stigg-price-text"
|
|
1032
1284
|
}, React__default.createElement(React__default.Fragment, null, withStartingAtRow && React__default.createElement(Typography, {
|
|
@@ -1052,57 +1304,75 @@ function PlanPrice(_ref6) {
|
|
|
1052
1304
|
billingPeriod: billingPeriod,
|
|
1053
1305
|
hasAnnuallyPrice: hasAnnuallyPrice,
|
|
1054
1306
|
hasMonthlyPrice: hasMonthlyPrice
|
|
1055
|
-
}))
|
|
1056
|
-
|
|
1307
|
+
})), withTiersRow && React__default.createElement(TiersLayout, {
|
|
1308
|
+
plan: plan,
|
|
1309
|
+
tiers: tiers,
|
|
1310
|
+
tierUnits: tierUnits,
|
|
1311
|
+
selectedTier: selectedTier,
|
|
1312
|
+
handleTierChange: handleTierChange
|
|
1313
|
+
})));
|
|
1314
|
+
};
|
|
1057
1315
|
|
|
1058
|
-
function
|
|
1059
|
-
var plan = _ref7.plan,
|
|
1060
|
-
billingPeriod = _ref7.billingPeriod,
|
|
1061
|
-
hasMonthlyPrice = _ref7.hasMonthlyPrice,
|
|
1062
|
-
hasAnnuallyPrice = _ref7.hasAnnuallyPrice;
|
|
1063
|
-
var hasPrice = plan.pricePoints.find(function (pricePoint) {
|
|
1064
|
-
return pricePoint.billingPeriod === billingPeriod;
|
|
1065
|
-
});
|
|
1066
|
-
var content = EMPTY_CHAR;
|
|
1316
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$4() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
1067
1317
|
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1318
|
+
var PlanOfferingContainer = /*#__PURE__*/_styled("div", {
|
|
1319
|
+
target: "eacdu8d8",
|
|
1320
|
+
label: "PlanOfferingContainer"
|
|
1321
|
+
})("position:relative;background-color:", function (_ref) {
|
|
1322
|
+
var theme = _ref.theme,
|
|
1323
|
+
$isCurrentPlan = _ref.$isCurrentPlan;
|
|
1324
|
+
return $isCurrentPlan ? theme.stigg.palette.backgroundHighlight : theme.stigg.palette.backgroundPaper;
|
|
1325
|
+
}, ";border:", function (_ref2) {
|
|
1326
|
+
var theme = _ref2.theme,
|
|
1327
|
+
$isHighlighted = _ref2.$isHighlighted;
|
|
1328
|
+
return $isHighlighted ? "3px solid " + theme.stigg.palette.primary : "1px solid " + theme.stigg.palette.outlinedBorder;
|
|
1329
|
+
}, ";border-radius:10px;padding:", function (_ref3) {
|
|
1330
|
+
var theme = _ref3.theme;
|
|
1331
|
+
return theme.stigg.layout.planPadding;
|
|
1332
|
+
}, ";display:flex;min-width:", function (_ref4) {
|
|
1333
|
+
var theme = _ref4.theme;
|
|
1334
|
+
return theme.stigg.layout.planMinWidth;
|
|
1335
|
+
}, ";max-width:", function (_ref5) {
|
|
1336
|
+
var theme = _ref5.theme;
|
|
1337
|
+
return theme.stigg.layout.planMaxWidth;
|
|
1338
|
+
}, ";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":"AAWyC","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */"));
|
|
1071
1339
|
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1340
|
+
var PlanHeader = /*#__PURE__*/_styled(Typography, {
|
|
1341
|
+
target: "eacdu8d7",
|
|
1342
|
+
label: "PlanHeader"
|
|
1343
|
+
})( {
|
|
1344
|
+
name: "mpkj0c",
|
|
1345
|
+
styles: "padding-bottom:8px",
|
|
1346
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAyBsC","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */",
|
|
1347
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4
|
|
1348
|
+
});
|
|
1079
1349
|
|
|
1080
1350
|
var Divider = /*#__PURE__*/_styled("div", {
|
|
1081
1351
|
target: "eacdu8d6",
|
|
1082
1352
|
label: "Divider"
|
|
1083
|
-
})("height:2px;width:100%;background-color:", function (
|
|
1084
|
-
var theme =
|
|
1353
|
+
})("height:2px;width:100%;background-color:", function (_ref6) {
|
|
1354
|
+
var theme = _ref6.theme;
|
|
1085
1355
|
return theme.stigg.palette.outlinedBorder;
|
|
1086
|
-
}, ";margin-bottom:40px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAwD2B","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */"));
|
|
1356
|
+
}, ";margin-bottom:40px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA4B2B","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */"));
|
|
1087
1357
|
|
|
1088
1358
|
var PlanDescription = /*#__PURE__*/_styled(Typography, {
|
|
1089
1359
|
target: "eacdu8d5",
|
|
1090
1360
|
label: "PlanDescription"
|
|
1091
|
-
})("text-align:", function (
|
|
1092
|
-
var theme =
|
|
1361
|
+
})("text-align:", function (_ref7) {
|
|
1362
|
+
var theme = _ref7.theme;
|
|
1093
1363
|
return theme.stigg.layout.descriptionAlignment;
|
|
1094
|
-
}, ";min-height:", function (
|
|
1095
|
-
var theme =
|
|
1364
|
+
}, ";min-height:", function (_ref8) {
|
|
1365
|
+
var theme = _ref8.theme;
|
|
1096
1366
|
return theme.stigg.layout.descriptionMinHeight;
|
|
1097
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA8D2C","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */"));
|
|
1367
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAkC2C","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */"));
|
|
1098
1368
|
|
|
1099
1369
|
var HighlightBadge = /*#__PURE__*/_styled("div", {
|
|
1100
1370
|
target: "eacdu8d4",
|
|
1101
1371
|
label: "HighlightBadge"
|
|
1102
|
-
})("background-color:", function (
|
|
1103
|
-
var theme =
|
|
1372
|
+
})("background-color:", function (_ref9) {
|
|
1373
|
+
var theme = _ref9.theme;
|
|
1104
1374
|
return theme.stigg.palette.primary;
|
|
1105
|
-
}, ";border-radius:40px;position:absolute;top:-12px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAkEkC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */"));
|
|
1375
|
+
}, ";border-radius:40px;position:absolute;top:-12px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAsCkC","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */"));
|
|
1106
1376
|
|
|
1107
1377
|
var HighlightText = /*#__PURE__*/_styled(Typography, {
|
|
1108
1378
|
target: "eacdu8d3",
|
|
@@ -1110,38 +1380,38 @@ var HighlightText = /*#__PURE__*/_styled(Typography, {
|
|
|
1110
1380
|
})( {
|
|
1111
1381
|
name: "a8c38r",
|
|
1112
1382
|
styles: "margin:0;padding:2px 8px",
|
|
1113
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAwEyC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */",
|
|
1114
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
1383
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA4CyC","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */",
|
|
1384
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4
|
|
1115
1385
|
});
|
|
1116
1386
|
|
|
1117
1387
|
var HeaderWrapper = /*#__PURE__*/_styled("div", {
|
|
1118
1388
|
target: "eacdu8d2",
|
|
1119
1389
|
label: "HeaderWrapper"
|
|
1120
|
-
})("width:100%;display:flex;flex-direction:column;align-items:", function (
|
|
1121
|
-
var theme =
|
|
1390
|
+
})("width:100%;display:flex;flex-direction:column;align-items:", function (_ref10) {
|
|
1391
|
+
var theme = _ref10.theme;
|
|
1122
1392
|
return flexLayoutMapper(theme.stigg.layout.headerAlignment);
|
|
1123
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA4EiC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */"));
|
|
1393
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAgDiC","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */"));
|
|
1124
1394
|
|
|
1125
1395
|
var NextPlanTagContainer = /*#__PURE__*/_styled("div", {
|
|
1126
1396
|
target: "eacdu8d1",
|
|
1127
1397
|
label: "NextPlanTagContainer"
|
|
1128
|
-
})("position:absolute;top:0;background-color:", function (
|
|
1129
|
-
var theme =
|
|
1398
|
+
})("position:absolute;top:0;background-color:", function (_ref11) {
|
|
1399
|
+
var theme = _ref11.theme;
|
|
1130
1400
|
return theme.stigg.palette.outlinedBorder;
|
|
1131
|
-
}, ";border-radius:0px 0px 10px 10px;padding:3px 12px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAkFwC","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */"));
|
|
1401
|
+
}, ";border-radius:0px 0px 10px 10px;padding:3px 12px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAsDwC","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */"));
|
|
1132
1402
|
|
|
1133
1403
|
var StyledMiniSchedule = /*#__PURE__*/_styled(SvgMiniSchedule, {
|
|
1134
1404
|
target: "eacdu8d0",
|
|
1135
1405
|
label: "StyledMiniSchedule"
|
|
1136
|
-
})("display:flex;height:100%;margin-right:
|
|
1137
|
-
var theme =
|
|
1406
|
+
})("display:flex;height:100%;margin-right:4px;path{fill:", function (_ref12) {
|
|
1407
|
+
var theme = _ref12.theme;
|
|
1138
1408
|
return theme.stigg.palette.text.primary;
|
|
1139
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AAyFgD","file":"PlanOffering.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { getPlanPrice } from '../utils/getPlanPrice';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nconst EMPTY_CHAR = '‎';\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 PlanPriceContainer = styled(Typography) `\n  word-break: break-word;\n`;\r\nconst UnitSpan = styled(Typography) `\n  white-space: nowrap;\n`;\r\nconst PriceSpan = styled(Typography) `\n  white-space: normal;\n  min-height: 39px;\n`;\r\nfunction PlanPrice({ showStartingAt, withUnitPriceRow, withStartingAtRow, plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, hasAnnuallyPrice, }) {\r\n    const { price, unit } = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice);\r\n    return (React.createElement(PlanPriceContainer, { className: \"stigg-price-text\" },\r\n        React.createElement(React.Fragment, null,\r\n            withStartingAtRow && (React.createElement(Typography, { style: { minHeight: '20px' }, className: \"stigg-starting-at-text\", variant: \"body1\", color: \"secondary\" }, showStartingAt ? paywallLocale.price.startingAtCaption : EMPTY_CHAR)),\r\n            React.createElement(PriceSpan, { variant: \"h1\" }, price),\r\n            withUnitPriceRow && (React.createElement(Typography, { className: \"stigg-price-unit-and-billing-period-text\", style: { minHeight: '48px' } },\r\n                React.createElement(UnitSpan, { span: true, variant: \"h6\", color: \"secondary\" }, unit),\r\n                React.createElement(PriceBillingPeriod, { plan: plan, billingPeriod: billingPeriod, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }))))));\r\n}\r\nfunction PriceBillingPeriod({ plan, billingPeriod, hasMonthlyPrice, hasAnnuallyPrice }) {\r\n    const hasPrice = plan.pricePoints.find(pricePoint => pricePoint.billingPeriod === billingPeriod);\r\n    let content = EMPTY_CHAR;\r\n    if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {\r\n        content = `, billed ${billingPeriod.toLowerCase()}`;\r\n    }\r\n    return (React.createElement(Typography, { span: true, className: \"stigg-price-billing-period-text\", variant: \"h6\", color: \"secondary\" }, content));\r\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: 4;\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, customer, plan, billingPeriod, isHighlighted, currentSubscription, shouldShowDescriptionSection, hasMonthlyPrice, hasAnnuallyPrice, isCustomerOnTrial, onPlanSelected, paywallLocale, locale, withStartingAtRow, }) {\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    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    return (React.createElement(PlanOfferingContainer, { className: classNames('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, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanSelected, paywallLocale: paywallLocale }),\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"]} */"));
|
|
1409
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PlanOffering.tsx"],"names":[],"mappings":"AA6DgD","file":"PlanOffering.tsx","sourcesContent":["import React, { useEffect } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { PlanEntitlements } from './PlanEntitlements';\r\nimport { PlanOfferingButton } from './PlanOfferingButton';\r\nimport { flexLayoutMapper } from '../../theme/getResolvedTheme';\r\nimport { Typography } from '../common/Typography';\r\nimport classNames from 'classnames';\r\nimport { Grid } from '@mui/material';\r\nimport MiniSchedule from '../../assets/mini-schedule.svg';\r\nimport { PlanPrice } from './PlanPrice';\r\nimport { getSelectedTier } from './planPriceTier';\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, }) {\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    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 [selectedTierByFeature, setSelectedTierByFeature] = React.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {}));\r\n    useEffect(() => {\r\n        setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));\r\n    }, [billingPeriod]);\r\n    const onPlanButtonClick = (intentionType) => {\r\n        const billableFeatures = Object.keys(selectedTierByFeature).map(featureId => ({\r\n            featureId,\r\n            quantity: selectedTierByFeature[featureId].upTo,\r\n        }));\r\n        return onPlanSelected(intentionType, billableFeatures);\r\n    };\r\n    return (React.createElement(PlanOfferingContainer, { className: classNames('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, selectedTierByFeature: selectedTierByFeature, setSelectedTierByFeature: setSelectedTierByFeature, plan: plan, billingPeriod: billingPeriod, paywallLocale: paywallLocale, locale: locale, hasAnnuallyPrice: hasAnnuallyPrice, hasMonthlyPrice: hasMonthlyPrice }),\r\n            React.createElement(PlanOfferingButton, { isNextPlan: isNextPlan, customer: customer, plan: plan, currentSubscription: currentSubscription, billingPeriod: billingPeriod, isCustomerOnTrial: isCustomerOnTrial, onPlanSelected: onPlanButtonClick, paywallLocale: paywallLocale, hasTiersRow: withTiersRow, withTrialLeftRow: withTrialLeftRow, selectedTierByFeature: selectedTierByFeature }),\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"]} */"));
|
|
1140
1410
|
|
|
1141
|
-
function UpcomingChangeTag(
|
|
1142
|
-
var
|
|
1143
|
-
text =
|
|
1144
|
-
iconsColor =
|
|
1411
|
+
function UpcomingChangeTag(_ref13) {
|
|
1412
|
+
var _ref13$text = _ref13.text,
|
|
1413
|
+
text = _ref13$text === void 0 ? 'Next' : _ref13$text,
|
|
1414
|
+
iconsColor = _ref13.iconsColor;
|
|
1145
1415
|
return React__default.createElement(NextPlanTagContainer, null, React__default.createElement(material.Grid, {
|
|
1146
1416
|
display: "flex",
|
|
1147
1417
|
alignItems: "center",
|
|
@@ -1154,23 +1424,25 @@ function UpcomingChangeTag(_ref15) {
|
|
|
1154
1424
|
}, text)));
|
|
1155
1425
|
}
|
|
1156
1426
|
|
|
1157
|
-
function PlanOffering(
|
|
1427
|
+
function PlanOffering(_ref14) {
|
|
1158
1428
|
var _plan$paywallCalculat;
|
|
1159
1429
|
|
|
1160
|
-
var withUnitPriceRow =
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
|
|
1173
|
-
|
|
1430
|
+
var withUnitPriceRow = _ref14.withUnitPriceRow,
|
|
1431
|
+
withTiersRow = _ref14.withTiersRow,
|
|
1432
|
+
withTrialLeftRow = _ref14.withTrialLeftRow,
|
|
1433
|
+
customer = _ref14.customer,
|
|
1434
|
+
plan = _ref14.plan,
|
|
1435
|
+
billingPeriod = _ref14.billingPeriod,
|
|
1436
|
+
isHighlighted = _ref14.isHighlighted,
|
|
1437
|
+
currentSubscription = _ref14.currentSubscription,
|
|
1438
|
+
shouldShowDescriptionSection = _ref14.shouldShowDescriptionSection,
|
|
1439
|
+
hasMonthlyPrice = _ref14.hasMonthlyPrice,
|
|
1440
|
+
hasAnnuallyPrice = _ref14.hasAnnuallyPrice,
|
|
1441
|
+
isCustomerOnTrial = _ref14.isCustomerOnTrial,
|
|
1442
|
+
onPlanSelected = _ref14.onPlanSelected,
|
|
1443
|
+
paywallLocale = _ref14.paywallLocale,
|
|
1444
|
+
locale = _ref14.locale,
|
|
1445
|
+
withStartingAtRow = _ref14.withStartingAtRow;
|
|
1174
1446
|
var isNextPlan = plan.isNextPlan && plan.isNextPlan(billingPeriod);
|
|
1175
1447
|
var planPrices = plan.pricePoints.filter(function (pricePoint) {
|
|
1176
1448
|
return pricePoint.billingPeriod === billingPeriod;
|
|
@@ -1195,6 +1467,24 @@ function PlanOffering(_ref16) {
|
|
|
1195
1467
|
}, paywallLocale.highlightChip));
|
|
1196
1468
|
}
|
|
1197
1469
|
|
|
1470
|
+
var _React$useState = React__default.useState(getSelectedTier(plan, billingPeriod, currentSubscription, {})),
|
|
1471
|
+
selectedTierByFeature = _React$useState[0],
|
|
1472
|
+
setSelectedTierByFeature = _React$useState[1];
|
|
1473
|
+
|
|
1474
|
+
React.useEffect(function () {
|
|
1475
|
+
setSelectedTierByFeature(getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature));
|
|
1476
|
+
}, [billingPeriod]);
|
|
1477
|
+
|
|
1478
|
+
var onPlanButtonClick = function onPlanButtonClick(intentionType) {
|
|
1479
|
+
var billableFeatures = Object.keys(selectedTierByFeature).map(function (featureId) {
|
|
1480
|
+
return {
|
|
1481
|
+
featureId: featureId,
|
|
1482
|
+
quantity: selectedTierByFeature[featureId].upTo
|
|
1483
|
+
};
|
|
1484
|
+
});
|
|
1485
|
+
return onPlanSelected(intentionType, billableFeatures);
|
|
1486
|
+
};
|
|
1487
|
+
|
|
1198
1488
|
return React__default.createElement(PlanOfferingContainer, {
|
|
1199
1489
|
className: classNames('stigg-plan-offering-container', {
|
|
1200
1490
|
'stigg-current-plan': plan.isCurrentCustomerPlan
|
|
@@ -1212,8 +1502,11 @@ function PlanOffering(_ref16) {
|
|
|
1212
1502
|
color: "secondary"
|
|
1213
1503
|
}, plan.description), React__default.createElement(PlanPrice, {
|
|
1214
1504
|
showStartingAt: showStartingAt,
|
|
1215
|
-
withUnitPriceRow:
|
|
1216
|
-
withStartingAtRow:
|
|
1505
|
+
withUnitPriceRow: withUnitPriceRow,
|
|
1506
|
+
withStartingAtRow: withStartingAtRow,
|
|
1507
|
+
withTiersRow: withTiersRow,
|
|
1508
|
+
selectedTierByFeature: selectedTierByFeature,
|
|
1509
|
+
setSelectedTierByFeature: setSelectedTierByFeature,
|
|
1217
1510
|
plan: plan,
|
|
1218
1511
|
billingPeriod: billingPeriod,
|
|
1219
1512
|
paywallLocale: paywallLocale,
|
|
@@ -1227,8 +1520,11 @@ function PlanOffering(_ref16) {
|
|
|
1227
1520
|
currentSubscription: currentSubscription,
|
|
1228
1521
|
billingPeriod: billingPeriod,
|
|
1229
1522
|
isCustomerOnTrial: isCustomerOnTrial,
|
|
1230
|
-
onPlanSelected:
|
|
1231
|
-
paywallLocale: paywallLocale
|
|
1523
|
+
onPlanSelected: onPlanButtonClick,
|
|
1524
|
+
paywallLocale: paywallLocale,
|
|
1525
|
+
hasTiersRow: withTiersRow,
|
|
1526
|
+
withTrialLeftRow: withTrialLeftRow,
|
|
1527
|
+
selectedTierByFeature: selectedTierByFeature
|
|
1232
1528
|
}), React__default.createElement(Divider, {
|
|
1233
1529
|
className: "stigg-plan-header-divider"
|
|
1234
1530
|
})), React__default.createElement(PlanEntitlements, {
|
|
@@ -1238,7 +1534,7 @@ function PlanOffering(_ref16) {
|
|
|
1238
1534
|
}));
|
|
1239
1535
|
}
|
|
1240
1536
|
|
|
1241
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
1537
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
1242
1538
|
|
|
1243
1539
|
var PickerContainer = /*#__PURE__*/_styled("div", {
|
|
1244
1540
|
target: "esqa6i42",
|
|
@@ -1261,7 +1557,7 @@ var PeriodText = /*#__PURE__*/_styled(Typography, {
|
|
|
1261
1557
|
name: "zvmrfm",
|
|
1262
1558
|
styles: "margin:0 8px",
|
|
1263
1559
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCc0MiLCJmaWxlIjoiQmlsbGluZ1BlcmlvZFBpY2tlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBTd2l0Y2ggZnJvbSAncmVhY3Qtc3dpdGNoJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZCB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuY29uc3QgUGlja2VyQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGhlaWdodDogNDBweDtcbiAgcGFkZGluZzogMCAyMHB4O1xuICBtYXJnaW4tYm90dG9tOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5zd2l0Y2hCb3R0b21TcGFjaW5nfTtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5gO1xyXG5jb25zdCBQZXJpb2RUZXh0ID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgbWFyZ2luOiAwIDhweDtcbmA7XHJcbmNvbnN0IFN0eWxlZFN3aXRjaCA9IHN0eWxlZChTd2l0Y2gpIGBcbiAgJiAucmVhY3Qtc3dpdGNoLWJnIHtcbiAgICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUuc3dpdGNoQm9yZGVyfWB9O1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5zd2l0Y2hGaWxsfSAhaW1wb3J0YW50O1xuICB9XG5cbiAgJiAucmVhY3Qtc3dpdGNoLWhhbmRsZSB7XG4gICAgYm94LXNoYWRvdzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5zaGFkb3dzLmxpZ2h0fTtcbiAgICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUuc3dpdGNoSGFuZGxlfSAhaW1wb3J0YW50O1xuICAgIHRvcDogMC41cHggIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZnVuY3Rpb24gRGlzY291bnRSYXRlKHsgZGlzY291bnQsIGRpc2FibGVkIH0pIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IGRpc2FibGVkID8gJ2Rpc2FibGVkJyA6ICdwcmltYXJ5JywgY2xhc3NOYW1lOiBcInN0aWdnLWRpc2NvdW50LXJhdGUtdGV4dFwiIH0sXHJcbiAgICAgICAgZGlzY291bnQsXHJcbiAgICAgICAgXCIlIG9mZlwiKSk7XHJcbn1cclxuZXhwb3J0IGZ1bmN0aW9uIEJpbGxpbmdQZXJpb2RQaWNrZXIoeyBkaXNjb3VudFJhdGUsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIH0pIHtcclxuICAgIGlmIChhdmFpbGFibGVCaWxsaW5nUGVyaW9kcy5sZW5ndGggPD0gMSkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgY29uc3QgaXNNb250aGx5QmlsbGluZ1BlcmlvZCA9IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCA9PT0gQmlsbGluZ1BlcmlvZC5Nb250aGx5O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBpY2tlckNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGVyaW9kLXBpY2tlci1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGVyaW9kVGV4dCwgeyB2YXJpYW50OiBcImg2XCIsIGNsYXNzTmFtZTogXCJzdGlnZy1tb250aGx5LXBlcmlvZC10ZXh0XCIsIGNvbG9yOiBpc01vbnRobHlCaWxsaW5nUGVyaW9kID8gJ3ByaW1hcnknIDogJ2Rpc2FibGVkJyB9LCBcIk1vbnRobHlcIiksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTd2l0Y2gsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBlcmlvZC1zd2l0Y2hcIiwgdW5jaGVja2VkSWNvbjogZmFsc2UsIGNoZWNrZWRJY29uOiBmYWxzZSwgaGVpZ2h0OiAxNiwgd2lkdGg6IDMzLCBvbkNoYW5nZTogaXNBbm51YWxseVNlbGVjdGVkID0+IG9uQmlsbGluZ1BlcmlvZENoYW5nZWQoaXNBbm51YWxseVNlbGVjdGVkID8gQmlsbGluZ1BlcmlvZC5Bbm51YWxseSA6IEJpbGxpbmdQZXJpb2QuTW9udGhseSksIGNoZWNrZWQ6ICFpc01vbnRobHlCaWxsaW5nUGVyaW9kLCBib3JkZXJSYWRpdXM6IDEwLCBoYW5kbGVEaWFtZXRlcjogMTkgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQZXJpb2RUZXh0LCB7IHZhcmlhbnQ6IFwiaDZcIiwgY2xhc3NOYW1lOiBcInN0aWdnLWFubnVhbC1wZXJpb2QtdGV4dFwiLCBjb2xvcjogIWlzTW9udGhseUJpbGxpbmdQZXJpb2QgPyAncHJpbWFyeScgOiAnZGlzYWJsZWQnIH0sIFwiQW5udWFsXCIpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRGlzY291bnRSYXRlLCB7IGRpc2NvdW50OiBkaXNjb3VudFJhdGUsIGRpc2FibGVkOiBpc01vbnRobHlCaWxsaW5nUGVyaW9kIH0pKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QmlsbGluZ1BlcmlvZFBpY2tlci5qcy5tYXAiXX0= */",
|
|
1264
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
1560
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
1265
1561
|
});
|
|
1266
1562
|
|
|
1267
1563
|
var StyledSwitch = /*#__PURE__*/_styled(Switch, {
|
|
@@ -1451,7 +1747,7 @@ function getPlansToDisplay(plans, selectedBillingPeriod) {
|
|
|
1451
1747
|
});
|
|
1452
1748
|
}
|
|
1453
1749
|
|
|
1454
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
1750
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
1455
1751
|
|
|
1456
1752
|
var PaywallPlansContainer = /*#__PURE__*/_styled("div", {
|
|
1457
1753
|
target: "e19kubi82",
|
|
@@ -1462,7 +1758,7 @@ var PaywallPlansContainer = /*#__PURE__*/_styled("div", {
|
|
|
1462
1758
|
}, ";display:flex;align-items:stretch;justify-content:center;flex-wrap:wrap;padding:10px 0;gap:", function (_ref2) {
|
|
1463
1759
|
var theme = _ref2.theme;
|
|
1464
1760
|
return theme.stigg.layout.planMargin;
|
|
1465
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1761
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVl5QyIsImZpbGUiOiJQYXl3YWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpbGxpbmdQZXJpb2QgfSBmcm9tICdAc3RpZ2cvanMtY2xpZW50LXNkayc7XHJcbmltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBQbGFuT2ZmZXJpbmcgfSBmcm9tICcuL1BsYW5PZmZlcmluZyc7XHJcbmltcG9ydCB7IEJpbGxpbmdQZXJpb2RQaWNrZXIgfSBmcm9tICcuL0JpbGxpbmdQZXJpb2RQaWNrZXInO1xyXG5pbXBvcnQgeyBjYWxjdWxhdGVQYXl3YWxsRGlzY291bnRSYXRlIH0gZnJvbSAnLi4vdXRpbHMvY2FsY3VsYXRlRGlzY291bnRSYXRlJztcclxuaW1wb3J0IHsgUG93ZXJlZEJ5U3RpZ2cgfSBmcm9tICcuLi9jb21tb24vUG93ZXJlZEJ5U3RpZ2cnO1xyXG5pbXBvcnQgeyB1c2VTdGlnZ0NvbnRleHQgfSBmcm9tICcuLi8uLic7XHJcbmltcG9ydCB7IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMgfSBmcm9tICcuL3V0aWxzL2hhc1ByaWNlUG9pbnRzJztcclxuaW1wb3J0IHsgZ2V0UGxhbnNUb0Rpc3BsYXkgfSBmcm9tICcuL3V0aWxzL2dldFBsYW5zVG9EaXNwbGF5JztcclxuaW1wb3J0IHsgZ2V0UGxhblByaWNlIH0gZnJvbSAnLi4vdXRpbHMvZ2V0UGxhblByaWNlJztcclxuaW1wb3J0IHsgZ2V0U2VsZWN0ZWRUaWVyIH0gZnJvbSAnLi9wbGFuUHJpY2VUaWVyJztcclxuY29uc3QgUGF5d2FsbFBsYW5zQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUudGV4dC5wcmltYXJ5fTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHBhZGRpbmc6IDEwcHggMDtcbiAgZ2FwOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5wbGFuTWFyZ2lufTtcbmA7XHJcbmNvbnN0IFBheXdhbGxDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAmICoge1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gIH1cbmA7XHJcbmNvbnN0IFBheXdhbGxMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XHJcbmV4cG9ydCBjb25zdCBQYXl3YWxsID0gKHsgcGxhbnMsIGN1c3RvbWVyLCBjdXJyZW50U3Vic2NyaXB0aW9uLCBoaWdobGlnaHRlZFBsYW5JZCwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBhdmFpbGFibGVCaWxsaW5nUGVyaW9kcywgaXNDdXN0b21lck9uVHJpYWwsIG9uUGxhblNlbGVjdGVkLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc3RpZ2cgfSA9IHVzZVN0aWdnQ29udGV4dCgpO1xyXG4gICAgY29uc3QgZGlzY291bnRSYXRlID0gY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZShwbGFucyk7XHJcbiAgICBjb25zdCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uID0gcGxhbnMuc29tZShwbGFuID0+ICEhcGxhbi5kZXNjcmlwdGlvbik7XHJcbiAgICBjb25zdCBoYXNNb250aGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLk1vbnRobHkpO1xyXG4gICAgY29uc3QgaGFzQW5udWFsbHlQcmljZSA9IGhhc1ByaWNlUG9pbnRzRm9yUGxhbnMocGxhbnMsIEJpbGxpbmdQZXJpb2QuQW5udWFsbHkpO1xyXG4gICAgY29uc3QgcGxhbnNUb1Nob3cgPSBnZXRQbGFuc1RvRGlzcGxheShwbGFucywgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgIGNvbnN0IGhhbmRsZU9uU3Vic2NyaWJlID0gdXNlQ2FsbGJhY2soKHBsYW4sIGludGVudGlvblR5cGUsIGJpbGxhYmxlRmVhdHVyZXMpID0+IHtcclxuICAgICAgICByZXR1cm4gb25QbGFuU2VsZWN0ZWQoe1xyXG4gICAgICAgICAgICBwbGFuLFxyXG4gICAgICAgICAgICBjdXN0b21lcixcclxuICAgICAgICAgICAgc3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLFxyXG4gICAgICAgICAgICBpbnRlbnRpb25UeXBlLFxyXG4gICAgICAgICAgICBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsXHJcbiAgICAgICAgICAgIGJpbGxhYmxlRmVhdHVyZXMsXHJcbiAgICAgICAgfSk7XHJcbiAgICB9LCBbY3VzdG9tZXIsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZF0pO1xyXG4gICAgY29uc3Qgd2l0aFN0YXJ0aW5nQXRSb3cgPSBwbGFuc1RvU2hvdy5zb21lKHBsYW4gPT4ge1xyXG4gICAgICAgIGNvbnN0IHBsYW5QcmljZXMgPSBwbGFuLnByaWNlUG9pbnRzLmZpbHRlcihwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICBjb25zdCBwYXl3YWxsQ2FsY3VsYXRlZFByaWNlID0gcGxhbi5wYXl3YWxsQ2FsY3VsYXRlZFByaWNlUG9pbnRzPy5maW5kKHByaWNlUG9pbnQgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBzZWxlY3RlZEJpbGxpbmdQZXJpb2QpO1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2VzLmxlbmd0aCA+IDEgJiYgISFwYXl3YWxsQ2FsY3VsYXRlZFByaWNlPy5hZGRpdGlvbmFsQ2hhcmdlc01heUFwcGx5O1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCB3aXRoVW5pdFByaWNlUm93ID0gcGxhbnNUb1Nob3cuc29tZShwbGFuID0+IHtcclxuICAgICAgICByZXR1cm4gISFnZXRQbGFuUHJpY2UocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSkudW5pdDtcclxuICAgIH0pO1xyXG4gICAgY29uc3Qgd2l0aFRpZXJzUm93ID0gcGxhbnNUb1Nob3cuc29tZShwbGFuID0+IHtcclxuICAgICAgICByZXR1cm4gISFnZXRTZWxlY3RlZFRpZXIocGxhbiwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLCBjdXJyZW50U3Vic2NyaXB0aW9uLCB7fSk7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IHdpdGhUcmlhbExlZnRSb3cgPSBwbGFuc1RvU2hvdy5zb21lKHBsYW4gPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuLmlzQ3VycmVudEN1c3RvbWVyUGxhbiAmJiBwbGFuLnRyaWFsRGF5c0xlZnQ7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsTGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLWxheW91dFwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZFBpY2tlciwgeyBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkOiBvbkJpbGxpbmdQZXJpb2RDaGFuZ2VkLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHM6IGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzLCBkaXNjb3VudFJhdGU6IGRpc2NvdW50UmF0ZSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQYXl3YWxsUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXBheXdhbGwtcGxhbnMtbGF5b3V0XCIgfSwgcGxhbnNUb1Nob3cubWFwKHBsYW4gPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nLCB7IHdpdGhVbml0UHJpY2VSb3c6IHdpdGhVbml0UHJpY2VSb3csIHdpdGhUaWVyc1Jvdzogd2l0aFRpZXJzUm93LCB3aXRoVHJpYWxMZWZ0Um93OiB3aXRoVHJpYWxMZWZ0Um93LCBrZXk6IHBsYW4uaWQsIHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb246IHNob3VsZFNob3dEZXNjcmlwdGlvblNlY3Rpb24sIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBwbGFuOiBwbGFuLCB3aXRoU3RhcnRpbmdBdFJvdzogd2l0aFN0YXJ0aW5nQXRSb3csIGN1cnJlbnRTdWJzY3JpcHRpb246IGN1cnJlbnRTdWJzY3JpcHRpb24sIGJpbGxpbmdQZXJpb2Q6IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgaXNIaWdobGlnaHRlZDogcGxhbi5pZCA9PT0gaGlnaGxpZ2h0ZWRQbGFuSWQsIGlzQ3VzdG9tZXJPblRyaWFsOiBpc0N1c3RvbWVyT25UcmlhbCwgb25QbGFuU2VsZWN0ZWQ6IChpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiBoYW5kbGVPblN1YnNjcmliZShwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSwgbG9jYWxlOiBsb2NhbGUsIGN1c3RvbWVyOiBjdXN0b21lciB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQb3dlcmVkQnlTdGlnZywgeyBzb3VyY2U6IFwicGF5d2FsbFwiLCBhbGlnbjogXCJlbmRcIiwgc3R5bGU6IHsgbWFyZ2luVG9wOiAxNiB9LCBzaG93V2F0ZXJtYXJrOiBzdGlnZy5pc1dpZGdldFdhdGVybWFya0VuYWJsZWQgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGwuanMubWFwIl19 */"));
|
|
1466
1762
|
|
|
1467
1763
|
var PaywallContainer = /*#__PURE__*/_styled("div", {
|
|
1468
1764
|
target: "e19kubi81",
|
|
@@ -1470,8 +1766,8 @@ var PaywallContainer = /*#__PURE__*/_styled("div", {
|
|
|
1470
1766
|
})( {
|
|
1471
1767
|
name: "1rdsyw8",
|
|
1472
1768
|
styles: "display:flex;flex-direction:column;align-items:center;& *{box-sizing:border-box;}",
|
|
1473
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1474
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
1769
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCb0MiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgUGxhbk9mZmVyaW5nIH0gZnJvbSAnLi9QbGFuT2ZmZXJpbmcnO1xyXG5pbXBvcnQgeyBCaWxsaW5nUGVyaW9kUGlja2VyIH0gZnJvbSAnLi9CaWxsaW5nUGVyaW9kUGlja2VyJztcclxuaW1wb3J0IHsgY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZSB9IGZyb20gJy4uL3V0aWxzL2NhbGN1bGF0ZURpc2NvdW50UmF0ZSc7XHJcbmltcG9ydCB7IFBvd2VyZWRCeVN0aWdnIH0gZnJvbSAnLi4vY29tbW9uL1Bvd2VyZWRCeVN0aWdnJztcclxuaW1wb3J0IHsgdXNlU3RpZ2dDb250ZXh0IH0gZnJvbSAnLi4vLi4nO1xyXG5pbXBvcnQgeyBoYXNQcmljZVBvaW50c0ZvclBsYW5zIH0gZnJvbSAnLi91dGlscy9oYXNQcmljZVBvaW50cyc7XHJcbmltcG9ydCB7IGdldFBsYW5zVG9EaXNwbGF5IH0gZnJvbSAnLi91dGlscy9nZXRQbGFuc1RvRGlzcGxheSc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IGdldFNlbGVjdGVkVGllciB9IGZyb20gJy4vcGxhblByaWNlVGllcic7XHJcbmNvbnN0IFBheXdhbGxQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnRleHQucHJpbWFyeX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBwYWRkaW5nOiAxMHB4IDA7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG5gO1xyXG5jb25zdCBQYXl3YWxsQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5jb25zdCBQYXl3YWxsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5leHBvcnQgY29uc3QgUGF5d2FsbCA9ICh7IHBsYW5zLCBjdXN0b21lciwgY3VycmVudFN1YnNjcmlwdGlvbiwgaGlnaGxpZ2h0ZWRQbGFuSWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHN0aWdnIH0gPSB1c2VTdGlnZ0NvbnRleHQoKTtcclxuICAgIGNvbnN0IGRpc2NvdW50UmF0ZSA9IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUocGxhbnMpO1xyXG4gICAgY29uc3Qgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiA9IHBsYW5zLnNvbWUocGxhbiA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICBjb25zdCBoYW5kbGVPblN1YnNjcmliZSA9IHVzZUNhbGxiYWNrKChwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIG9uUGxhblNlbGVjdGVkKHtcclxuICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgY3VzdG9tZXIsXHJcbiAgICAgICAgICAgIHN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgaW50ZW50aW9uVHlwZSxcclxuICAgICAgICAgICAgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLFxyXG4gICAgICAgICAgICBiaWxsYWJsZUZlYXR1cmVzLFxyXG4gICAgICAgIH0pO1xyXG4gICAgfSwgW2N1c3RvbWVyLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2RdKTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gcGxhbnNUb1Nob3cuc29tZShwbGFuID0+IHtcclxuICAgICAgICBjb25zdCBwbGFuUHJpY2VzID0gcGxhbi5wcmljZVBvaW50cy5maWx0ZXIocHJpY2VQb2ludCA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlcy5sZW5ndGggPiAxICYmICEhcGF5d2FsbENhbGN1bGF0ZWRQcmljZT8uYWRkaXRpb25hbENoYXJnZXNNYXlBcHBseTtcclxuICAgIH0pO1xyXG4gICAgY29uc3Qgd2l0aFVuaXRQcmljZVJvdyA9IHBsYW5zVG9TaG93LnNvbWUocGxhbiA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IHdpdGhUaWVyc1JvdyA9IHBsYW5zVG9TaG93LnNvbWUocGxhbiA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0U2VsZWN0ZWRUaWVyKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgY3VycmVudFN1YnNjcmlwdGlvbiwge30pO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZShwbGFuID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhbi5pc0N1cnJlbnRDdXN0b21lclBsYW4gJiYgcGxhbi50cmlhbERheXNMZWZ0O1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbENvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbExheW91dCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1sYXlvdXRcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJpbGxpbmdQZXJpb2RQaWNrZXIsIHsgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZDogb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzOiBhdmFpbGFibGVCaWxsaW5nUGVyaW9kcywgZGlzY291bnRSYXRlOiBkaXNjb3VudFJhdGUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbFBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLXBsYW5zLWxheW91dFwiIH0sIHBsYW5zVG9TaG93Lm1hcChwbGFuID0+IChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZywgeyB3aXRoVW5pdFByaWNlUm93OiB3aXRoVW5pdFByaWNlUm93LCB3aXRoVGllcnNSb3c6IHdpdGhUaWVyc1Jvdywgd2l0aFRyaWFsTGVmdFJvdzogd2l0aFRyaWFsTGVmdFJvdywga2V5OiBwbGFuLmlkLCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uOiBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZTogaGFzQW5udWFsbHlQcmljZSwgcGxhbjogcGxhbiwgd2l0aFN0YXJ0aW5nQXRSb3c6IHdpdGhTdGFydGluZ0F0Um93LCBjdXJyZW50U3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLCBiaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGlzSGlnaGxpZ2h0ZWQ6IHBsYW4uaWQgPT09IGhpZ2hsaWdodGVkUGxhbklkLCBpc0N1c3RvbWVyT25UcmlhbDogaXNDdXN0b21lck9uVHJpYWwsIG9uUGxhblNlbGVjdGVkOiAoaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4gaGFuZGxlT25TdWJzY3JpYmUocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcyksIHBheXdhbGxMb2NhbGU6IHBheXdhbGxMb2NhbGUsIGxvY2FsZTogbG9jYWxlLCBjdXN0b21lcjogY3VzdG9tZXIgfSkpKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUG93ZXJlZEJ5U3RpZ2csIHsgc291cmNlOiBcInBheXdhbGxcIiwgYWxpZ246IFwiZW5kXCIsIHN0eWxlOiB7IG1hcmdpblRvcDogMTYgfSwgc2hvd1dhdGVybWFyazogc3RpZ2cuaXNXaWRnZXRXYXRlcm1hcmtFbmFibGVkIH0pKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QYXl3YWxsLmpzLm1hcCJdfQ== */",
|
|
1770
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
1475
1771
|
});
|
|
1476
1772
|
|
|
1477
1773
|
var PaywallLayout = /*#__PURE__*/_styled("div", {
|
|
@@ -1480,8 +1776,8 @@ var PaywallLayout = /*#__PURE__*/_styled("div", {
|
|
|
1480
1776
|
})( {
|
|
1481
1777
|
name: "zigog8",
|
|
1482
1778
|
styles: "display:flex;flex-direction:column;align-items:center",
|
|
1483
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1484
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
1779
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCaUMiLCJmaWxlIjoiUGF5d2FsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCaWxsaW5nUGVyaW9kIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgUGxhbk9mZmVyaW5nIH0gZnJvbSAnLi9QbGFuT2ZmZXJpbmcnO1xyXG5pbXBvcnQgeyBCaWxsaW5nUGVyaW9kUGlja2VyIH0gZnJvbSAnLi9CaWxsaW5nUGVyaW9kUGlja2VyJztcclxuaW1wb3J0IHsgY2FsY3VsYXRlUGF5d2FsbERpc2NvdW50UmF0ZSB9IGZyb20gJy4uL3V0aWxzL2NhbGN1bGF0ZURpc2NvdW50UmF0ZSc7XHJcbmltcG9ydCB7IFBvd2VyZWRCeVN0aWdnIH0gZnJvbSAnLi4vY29tbW9uL1Bvd2VyZWRCeVN0aWdnJztcclxuaW1wb3J0IHsgdXNlU3RpZ2dDb250ZXh0IH0gZnJvbSAnLi4vLi4nO1xyXG5pbXBvcnQgeyBoYXNQcmljZVBvaW50c0ZvclBsYW5zIH0gZnJvbSAnLi91dGlscy9oYXNQcmljZVBvaW50cyc7XHJcbmltcG9ydCB7IGdldFBsYW5zVG9EaXNwbGF5IH0gZnJvbSAnLi91dGlscy9nZXRQbGFuc1RvRGlzcGxheSc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IGdldFNlbGVjdGVkVGllciB9IGZyb20gJy4vcGxhblByaWNlVGllcic7XHJcbmNvbnN0IFBheXdhbGxQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnRleHQucHJpbWFyeX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBzdHJldGNoO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBwYWRkaW5nOiAxMHB4IDA7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG5gO1xyXG5jb25zdCBQYXl3YWxsQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5jb25zdCBQYXl3YWxsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5leHBvcnQgY29uc3QgUGF5d2FsbCA9ICh7IHBsYW5zLCBjdXN0b21lciwgY3VycmVudFN1YnNjcmlwdGlvbiwgaGlnaGxpZ2h0ZWRQbGFuSWQsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgYXZhaWxhYmxlQmlsbGluZ1BlcmlvZHMsIGlzQ3VzdG9tZXJPblRyaWFsLCBvblBsYW5TZWxlY3RlZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHN0aWdnIH0gPSB1c2VTdGlnZ0NvbnRleHQoKTtcclxuICAgIGNvbnN0IGRpc2NvdW50UmF0ZSA9IGNhbGN1bGF0ZVBheXdhbGxEaXNjb3VudFJhdGUocGxhbnMpO1xyXG4gICAgY29uc3Qgc2hvdWxkU2hvd0Rlc2NyaXB0aW9uU2VjdGlvbiA9IHBsYW5zLnNvbWUocGxhbiA9PiAhIXBsYW4uZGVzY3JpcHRpb24pO1xyXG4gICAgY29uc3QgaGFzTW9udGhseVByaWNlID0gaGFzUHJpY2VQb2ludHNGb3JQbGFucyhwbGFucywgQmlsbGluZ1BlcmlvZC5Nb250aGx5KTtcclxuICAgIGNvbnN0IGhhc0FubnVhbGx5UHJpY2UgPSBoYXNQcmljZVBvaW50c0ZvclBsYW5zKHBsYW5zLCBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KTtcclxuICAgIGNvbnN0IHBsYW5zVG9TaG93ID0gZ2V0UGxhbnNUb0Rpc3BsYXkocGxhbnMsIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICBjb25zdCBoYW5kbGVPblN1YnNjcmliZSA9IHVzZUNhbGxiYWNrKChwbGFuLCBpbnRlbnRpb25UeXBlLCBiaWxsYWJsZUZlYXR1cmVzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIG9uUGxhblNlbGVjdGVkKHtcclxuICAgICAgICAgICAgcGxhbixcclxuICAgICAgICAgICAgY3VzdG9tZXIsXHJcbiAgICAgICAgICAgIHN1YnNjcmlwdGlvbjogY3VycmVudFN1YnNjcmlwdGlvbixcclxuICAgICAgICAgICAgaW50ZW50aW9uVHlwZSxcclxuICAgICAgICAgICAgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kLFxyXG4gICAgICAgICAgICBiaWxsYWJsZUZlYXR1cmVzLFxyXG4gICAgICAgIH0pO1xyXG4gICAgfSwgW2N1c3RvbWVyLCBzZWxlY3RlZEJpbGxpbmdQZXJpb2RdKTtcclxuICAgIGNvbnN0IHdpdGhTdGFydGluZ0F0Um93ID0gcGxhbnNUb1Nob3cuc29tZShwbGFuID0+IHtcclxuICAgICAgICBjb25zdCBwbGFuUHJpY2VzID0gcGxhbi5wcmljZVBvaW50cy5maWx0ZXIocHJpY2VQb2ludCA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IHNlbGVjdGVkQmlsbGluZ1BlcmlvZCk7XHJcbiAgICAgICAgY29uc3QgcGF5d2FsbENhbGN1bGF0ZWRQcmljZSA9IHBsYW4ucGF5d2FsbENhbGN1bGF0ZWRQcmljZVBvaW50cz8uZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gc2VsZWN0ZWRCaWxsaW5nUGVyaW9kKTtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlcy5sZW5ndGggPiAxICYmICEhcGF5d2FsbENhbGN1bGF0ZWRQcmljZT8uYWRkaXRpb25hbENoYXJnZXNNYXlBcHBseTtcclxuICAgIH0pO1xyXG4gICAgY29uc3Qgd2l0aFVuaXRQcmljZVJvdyA9IHBsYW5zVG9TaG93LnNvbWUocGxhbiA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0UGxhblByaWNlKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UpLnVuaXQ7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IHdpdGhUaWVyc1JvdyA9IHBsYW5zVG9TaG93LnNvbWUocGxhbiA9PiB7XHJcbiAgICAgICAgcmV0dXJuICEhZ2V0U2VsZWN0ZWRUaWVyKHBsYW4sIHNlbGVjdGVkQmlsbGluZ1BlcmlvZCwgY3VycmVudFN1YnNjcmlwdGlvbiwge30pO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCB3aXRoVHJpYWxMZWZ0Um93ID0gcGxhbnNUb1Nob3cuc29tZShwbGFuID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhbi5pc0N1cnJlbnRDdXN0b21lclBsYW4gJiYgcGxhbi50cmlhbERheXNMZWZ0O1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbENvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbExheW91dCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcGF5d2FsbC1sYXlvdXRcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJpbGxpbmdQZXJpb2RQaWNrZXIsIHsgb25CaWxsaW5nUGVyaW9kQ2hhbmdlZDogb25CaWxsaW5nUGVyaW9kQ2hhbmdlZCwgc2VsZWN0ZWRCaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGF2YWlsYWJsZUJpbGxpbmdQZXJpb2RzOiBhdmFpbGFibGVCaWxsaW5nUGVyaW9kcywgZGlzY291bnRSYXRlOiBkaXNjb3VudFJhdGUgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5d2FsbFBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wYXl3YWxsLXBsYW5zLWxheW91dFwiIH0sIHBsYW5zVG9TaG93Lm1hcChwbGFuID0+IChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZywgeyB3aXRoVW5pdFByaWNlUm93OiB3aXRoVW5pdFByaWNlUm93LCB3aXRoVGllcnNSb3c6IHdpdGhUaWVyc1Jvdywgd2l0aFRyaWFsTGVmdFJvdzogd2l0aFRyaWFsTGVmdFJvdywga2V5OiBwbGFuLmlkLCBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uOiBzaG91bGRTaG93RGVzY3JpcHRpb25TZWN0aW9uLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZTogaGFzQW5udWFsbHlQcmljZSwgcGxhbjogcGxhbiwgd2l0aFN0YXJ0aW5nQXRSb3c6IHdpdGhTdGFydGluZ0F0Um93LCBjdXJyZW50U3Vic2NyaXB0aW9uOiBjdXJyZW50U3Vic2NyaXB0aW9uLCBiaWxsaW5nUGVyaW9kOiBzZWxlY3RlZEJpbGxpbmdQZXJpb2QsIGlzSGlnaGxpZ2h0ZWQ6IHBsYW4uaWQgPT09IGhpZ2hsaWdodGVkUGxhbklkLCBpc0N1c3RvbWVyT25UcmlhbDogaXNDdXN0b21lck9uVHJpYWwsIG9uUGxhblNlbGVjdGVkOiAoaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcykgPT4gaGFuZGxlT25TdWJzY3JpYmUocGxhbiwgaW50ZW50aW9uVHlwZSwgYmlsbGFibGVGZWF0dXJlcyksIHBheXdhbGxMb2NhbGU6IHBheXdhbGxMb2NhbGUsIGxvY2FsZTogbG9jYWxlLCBjdXN0b21lcjogY3VzdG9tZXIgfSkpKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUG93ZXJlZEJ5U3RpZ2csIHsgc291cmNlOiBcInBheXdhbGxcIiwgYWxpZ246IFwiZW5kXCIsIHN0eWxlOiB7IG1hcmdpblRvcDogMTYgfSwgc2hvd1dhdGVybWFyazogc3RpZ2cuaXNXaWRnZXRXYXRlcm1hcmtFbmFibGVkIH0pKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QYXl3YWxsLmpzLm1hcCJdfQ== */",
|
|
1780
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
1485
1781
|
});
|
|
1486
1782
|
|
|
1487
1783
|
var Paywall = function Paywall(_ref3) {
|
|
@@ -1507,13 +1803,14 @@ var Paywall = function Paywall(_ref3) {
|
|
|
1507
1803
|
var hasMonthlyPrice = hasPricePointsForPlans(plans, Stigg.BillingPeriod.Monthly);
|
|
1508
1804
|
var hasAnnuallyPrice = hasPricePointsForPlans(plans, Stigg.BillingPeriod.Annually);
|
|
1509
1805
|
var plansToShow = getPlansToDisplay(plans, selectedBillingPeriod);
|
|
1510
|
-
var handleOnSubscribe = React.useCallback(function (plan, intentionType) {
|
|
1806
|
+
var handleOnSubscribe = React.useCallback(function (plan, intentionType, billableFeatures) {
|
|
1511
1807
|
return onPlanSelected({
|
|
1512
1808
|
plan: plan,
|
|
1513
1809
|
customer: customer,
|
|
1514
1810
|
subscription: currentSubscription,
|
|
1515
1811
|
intentionType: intentionType,
|
|
1516
|
-
selectedBillingPeriod: selectedBillingPeriod
|
|
1812
|
+
selectedBillingPeriod: selectedBillingPeriod,
|
|
1813
|
+
billableFeatures: billableFeatures
|
|
1517
1814
|
});
|
|
1518
1815
|
}, [customer, selectedBillingPeriod]);
|
|
1519
1816
|
var withStartingAtRow = plansToShow.some(function (plan) {
|
|
@@ -1530,6 +1827,12 @@ var Paywall = function Paywall(_ref3) {
|
|
|
1530
1827
|
var withUnitPriceRow = plansToShow.some(function (plan) {
|
|
1531
1828
|
return !!getPlanPrice(plan, selectedBillingPeriod, paywallLocale, locale, hasMonthlyPrice).unit;
|
|
1532
1829
|
});
|
|
1830
|
+
var withTiersRow = plansToShow.some(function (plan) {
|
|
1831
|
+
return !!getSelectedTier(plan, selectedBillingPeriod, currentSubscription, {});
|
|
1832
|
+
});
|
|
1833
|
+
var withTrialLeftRow = plansToShow.some(function (plan) {
|
|
1834
|
+
return plan.isCurrentCustomerPlan && plan.trialDaysLeft;
|
|
1835
|
+
});
|
|
1533
1836
|
return React__default.createElement(PaywallContainer, {
|
|
1534
1837
|
className: "stigg-paywall-container"
|
|
1535
1838
|
}, React__default.createElement(PaywallLayout, {
|
|
@@ -1544,6 +1847,8 @@ var Paywall = function Paywall(_ref3) {
|
|
|
1544
1847
|
}, plansToShow.map(function (plan) {
|
|
1545
1848
|
return React__default.createElement(PlanOffering, {
|
|
1546
1849
|
withUnitPriceRow: withUnitPriceRow,
|
|
1850
|
+
withTiersRow: withTiersRow,
|
|
1851
|
+
withTrialLeftRow: withTrialLeftRow,
|
|
1547
1852
|
key: plan.id,
|
|
1548
1853
|
shouldShowDescriptionSection: shouldShowDescriptionSection,
|
|
1549
1854
|
hasMonthlyPrice: hasMonthlyPrice,
|
|
@@ -1554,8 +1859,8 @@ var Paywall = function Paywall(_ref3) {
|
|
|
1554
1859
|
billingPeriod: selectedBillingPeriod,
|
|
1555
1860
|
isHighlighted: plan.id === highlightedPlanId,
|
|
1556
1861
|
isCustomerOnTrial: isCustomerOnTrial,
|
|
1557
|
-
onPlanSelected: function onPlanSelected(intentionType) {
|
|
1558
|
-
return handleOnSubscribe(plan, intentionType);
|
|
1862
|
+
onPlanSelected: function onPlanSelected(intentionType, billableFeatures) {
|
|
1863
|
+
return handleOnSubscribe(plan, intentionType, billableFeatures);
|
|
1559
1864
|
},
|
|
1560
1865
|
paywallLocale: paywallLocale,
|
|
1561
1866
|
locale: locale,
|
|
@@ -2935,7 +3240,7 @@ function getResolvedPaywallLocalize(localizeOverride) {
|
|
|
2935
3240
|
return merge(paywallDefaultLocalization, localizeOverride);
|
|
2936
3241
|
}
|
|
2937
3242
|
|
|
2938
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3243
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
2939
3244
|
|
|
2940
3245
|
var SkeletonContainer = /*#__PURE__*/_styled("div", {
|
|
2941
3246
|
target: "e1f7khji6",
|
|
@@ -2944,7 +3249,7 @@ var SkeletonContainer = /*#__PURE__*/_styled("div", {
|
|
|
2944
3249
|
name: "zigog8",
|
|
2945
3250
|
styles: "display:flex;flex-direction:column;align-items:center",
|
|
2946
3251
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGxMb2FkZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlxQyIsImZpbGUiOiJQYXl3YWxsTG9hZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IFNrZWxldG9uIGZyb20gJ3JlYWN0LWxvYWRpbmctc2tlbGV0b24nO1xyXG5pbXBvcnQgQ2hlY2tVcmwgZnJvbSAnLi4vLi4vYXNzZXRzL2NoZWNrLXN0aWdnLnN2Zyc7XHJcbmNvbnN0IFNrZWxldG9uQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5jb25zdCBFbnRpdGxlbWVudENoZWNrSWNvbiA9IHN0eWxlZChDaGVja1VybCkgYFxuICBtYXJnaW4tcmlnaHQ6IDE2cHg7XG5gO1xyXG5jb25zdCBQbGFuT2ZmZXJpbmdTa2VsZXRvbiA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAyMHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5wbGFuUGFkZGluZ307XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBtaW4td2lkdGg6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NaW5XaWR0aH07XG4gIG1heC13aWR0aDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1heFdpZHRofTtcbiAgbWluLWhlaWdodDogNDUwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcbmA7XHJcbmNvbnN0IFBsYW5zQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5gO1xyXG5jb25zdCBFbnRpdGxlbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tYm90dG9tOiAxMnB4O1xuYDtcclxuY29uc3QgRm9vdGVyU2tlbGV0b25Mb2FkZXIgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luLXRvcDogYXV0bztcbmA7XHJcbmNvbnN0IEJpbGxpbmdQZXJpb2RMb2FkZXIgPSBzdHlsZWQuZGl2IGBcbiAgd2lkdGg6IDE1MHB4O1xuICBtYXJnaW4tYm90dG9tOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5zd2l0Y2hCb3R0b21TcGFjaW5nfTtcbiAgcGFkZGluZzogMTJweCAxMnB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuYDtcclxuZnVuY3Rpb24gUGxhbk9mZmVyaW5nTG9hZGVyKCkge1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZ1NrZWxldG9uLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCwgYm9yZGVyUmFkaXVzOiA0IH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgY2lyY2xlOiB0cnVlLCB3aWR0aDogNDAsIGhlaWdodDogNDAgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyBzdHlsZTogeyBtYXJnaW5Cb3R0b206IDMzIH0sIHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q2hlY2tJY29uLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogMTIwLCBib3JkZXJSYWRpdXM6IDQgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDaGVja0ljb24sIG51bGwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENoZWNrSWNvbiwgbnVsbCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCwgYm9yZGVyUmFkaXVzOiA0IH0pKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEZvb3RlclNrZWxldG9uTG9hZGVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IGhlaWdodDogNTAsIGJvcmRlclJhZGl1czogNCB9KSkpKTtcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gUGF5d2FsbExvYWRlcigpIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbkNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2tlbGV0b24tbG9hZGVyLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChCaWxsaW5nUGVyaW9kTG9hZGVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1za2VsZXRvbi1sb2FkZXItYmlsbGluZy1wZXJpb2RcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IGJvcmRlclJhZGl1czogNCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuc0NvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2tlbGV0b24tbG9hZGVyLXBsYW5zLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nTG9hZGVyLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmdMb2FkZXIsIG51bGwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZ0xvYWRlciwgbnVsbCkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9UGF5d2FsbExvYWRlci5qcy5tYXAiXX0= */",
|
|
2947
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3252
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
2948
3253
|
});
|
|
2949
3254
|
|
|
2950
3255
|
var EntitlementCheckIcon$1 = /*#__PURE__*/_styled(SvgCheckStigg, {
|
|
@@ -2954,7 +3259,7 @@ var EntitlementCheckIcon$1 = /*#__PURE__*/_styled(SvgCheckStigg, {
|
|
|
2954
3259
|
name: "o7nnmj",
|
|
2955
3260
|
styles: "margin-right:16px",
|
|
2956
3261
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGxMb2FkZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVM4QyIsImZpbGUiOiJQYXl3YWxsTG9hZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IFNrZWxldG9uIGZyb20gJ3JlYWN0LWxvYWRpbmctc2tlbGV0b24nO1xyXG5pbXBvcnQgQ2hlY2tVcmwgZnJvbSAnLi4vLi4vYXNzZXRzL2NoZWNrLXN0aWdnLnN2Zyc7XHJcbmNvbnN0IFNrZWxldG9uQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xyXG5jb25zdCBFbnRpdGxlbWVudENoZWNrSWNvbiA9IHN0eWxlZChDaGVja1VybCkgYFxuICBtYXJnaW4tcmlnaHQ6IDE2cHg7XG5gO1xyXG5jb25zdCBQbGFuT2ZmZXJpbmdTa2VsZXRvbiA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAyMHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5wbGFuUGFkZGluZ307XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBtaW4td2lkdGg6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NaW5XaWR0aH07XG4gIG1heC13aWR0aDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1heFdpZHRofTtcbiAgbWluLWhlaWdodDogNDUwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcbmA7XHJcbmNvbnN0IFBsYW5zQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhbk1hcmdpbn07XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5gO1xyXG5jb25zdCBFbnRpdGxlbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tYm90dG9tOiAxMnB4O1xuYDtcclxuY29uc3QgRm9vdGVyU2tlbGV0b25Mb2FkZXIgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luLXRvcDogYXV0bztcbmA7XHJcbmNvbnN0IEJpbGxpbmdQZXJpb2RMb2FkZXIgPSBzdHlsZWQuZGl2IGBcbiAgd2lkdGg6IDE1MHB4O1xuICBtYXJnaW4tYm90dG9tOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5zd2l0Y2hCb3R0b21TcGFjaW5nfTtcbiAgcGFkZGluZzogMTJweCAxMnB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuYDtcclxuZnVuY3Rpb24gUGxhbk9mZmVyaW5nTG9hZGVyKCkge1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZ1NrZWxldG9uLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCwgYm9yZGVyUmFkaXVzOiA0IH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgY2lyY2xlOiB0cnVlLCB3aWR0aDogNDAsIGhlaWdodDogNDAgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyBzdHlsZTogeyBtYXJnaW5Cb3R0b206IDMzIH0sIHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q2hlY2tJY29uLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogMTIwLCBib3JkZXJSYWRpdXM6IDQgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDaGVja0ljb24sIG51bGwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENoZWNrSWNvbiwgbnVsbCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCwgYm9yZGVyUmFkaXVzOiA0IH0pKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEZvb3RlclNrZWxldG9uTG9hZGVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IGhlaWdodDogNTAsIGJvcmRlclJhZGl1czogNCB9KSkpKTtcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gUGF5d2FsbExvYWRlcigpIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbkNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2tlbGV0b24tbG9hZGVyLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChCaWxsaW5nUGVyaW9kTG9hZGVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1za2VsZXRvbi1sb2FkZXItYmlsbGluZy1wZXJpb2RcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IGJvcmRlclJhZGl1czogNCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuc0NvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2tlbGV0b24tbG9hZGVyLXBsYW5zLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nTG9hZGVyLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmdMb2FkZXIsIG51bGwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZ0xvYWRlciwgbnVsbCkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9UGF5d2FsbExvYWRlci5qcy5tYXAiXX0= */",
|
|
2957
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3262
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
2958
3263
|
});
|
|
2959
3264
|
|
|
2960
3265
|
var PlanOfferingSkeleton = /*#__PURE__*/_styled("div", {
|
|
@@ -2992,7 +3297,7 @@ var EntitlementContainer = /*#__PURE__*/_styled("div", {
|
|
|
2992
3297
|
name: "k8xojc",
|
|
2993
3298
|
styles: "display:flex;align-items:center;margin-bottom:12px",
|
|
2994
3299
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGxMb2FkZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCd0MiLCJmaWxlIjoiUGF5d2FsbExvYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBTa2VsZXRvbiBmcm9tICdyZWFjdC1sb2FkaW5nLXNrZWxldG9uJztcclxuaW1wb3J0IENoZWNrVXJsIGZyb20gJy4uLy4uL2Fzc2V0cy9jaGVjay1zdGlnZy5zdmcnO1xyXG5jb25zdCBTa2VsZXRvbkNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuY29uc3QgRW50aXRsZW1lbnRDaGVja0ljb24gPSBzdHlsZWQoQ2hlY2tVcmwpIGBcbiAgbWFyZ2luLXJpZ2h0OiAxNnB4O1xuYDtcclxuY29uc3QgUGxhbk9mZmVyaW5nU2tlbGV0b24gPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMjBweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhblBhZGRpbmd9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyfTtcbiAgbWluLXdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5wbGFuTWluV2lkdGh9O1xuICBtYXgtd2lkdGg6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXhXaWR0aH07XG4gIG1pbi1oZWlnaHQ6IDQ1MHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5gO1xyXG5jb25zdCBQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuYDtcclxuY29uc3QgRW50aXRsZW1lbnRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogMTJweDtcbmA7XHJcbmNvbnN0IEZvb3RlclNrZWxldG9uTG9hZGVyID0gc3R5bGVkLmRpdiBgXG4gIG1hcmdpbi10b3A6IGF1dG87XG5gO1xyXG5jb25zdCBCaWxsaW5nUGVyaW9kTG9hZGVyID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxNTBweDtcbiAgbWFyZ2luLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQuc3dpdGNoQm90dG9tU3BhY2luZ307XG4gIHBhZGRpbmc6IDEycHggMTJweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogd2hpdGU7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcbmA7XHJcbmZ1bmN0aW9uIFBsYW5PZmZlcmluZ0xvYWRlcigpIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmdTa2VsZXRvbiwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IGNpcmNsZTogdHJ1ZSwgd2lkdGg6IDQwLCBoZWlnaHQ6IDQwIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgc3R5bGU6IHsgbWFyZ2luQm90dG9tOiAzMyB9LCB3aWR0aDogMTIwLCBib3JkZXJSYWRpdXM6IDQgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENoZWNrSWNvbiwgbnVsbCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCwgYm9yZGVyUmFkaXVzOiA0IH0pKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q2hlY2tJY29uLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogMTIwLCBib3JkZXJSYWRpdXM6IDQgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDaGVja0ljb24sIG51bGwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChGb290ZXJTa2VsZXRvbkxvYWRlciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyBoZWlnaHQ6IDUwLCBib3JkZXJSYWRpdXM6IDQgfSkpKSk7XHJcbn1cclxuZXhwb3J0IGZ1bmN0aW9uIFBheXdhbGxMb2FkZXIoKSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25Db250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXNrZWxldG9uLWxvYWRlci1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZExvYWRlciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2tlbGV0b24tbG9hZGVyLWJpbGxpbmctcGVyaW9kXCIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyBib3JkZXJSYWRpdXM6IDQgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXNrZWxldG9uLWxvYWRlci1wbGFucy1jb250YWluZXJcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZ0xvYWRlciwgbnVsbCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nTG9hZGVyLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmdMb2FkZXIsIG51bGwpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGxMb2FkZXIuanMubWFwIl19 */",
|
|
2995
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3300
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
2996
3301
|
});
|
|
2997
3302
|
|
|
2998
3303
|
var FooterSkeletonLoader = /*#__PURE__*/_styled("div", {
|
|
@@ -3002,7 +3307,7 @@ var FooterSkeletonLoader = /*#__PURE__*/_styled("div", {
|
|
|
3002
3307
|
name: "xdvdnl",
|
|
3003
3308
|
styles: "margin-top:auto",
|
|
3004
3309
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBheXdhbGxMb2FkZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9Dd0MiLCJmaWxlIjoiUGF5d2FsbExvYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBTa2VsZXRvbiBmcm9tICdyZWFjdC1sb2FkaW5nLXNrZWxldG9uJztcclxuaW1wb3J0IENoZWNrVXJsIGZyb20gJy4uLy4uL2Fzc2V0cy9jaGVjay1zdGlnZy5zdmcnO1xyXG5jb25zdCBTa2VsZXRvbkNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcclxuY29uc3QgRW50aXRsZW1lbnRDaGVja0ljb24gPSBzdHlsZWQoQ2hlY2tVcmwpIGBcbiAgbWFyZ2luLXJpZ2h0OiAxNnB4O1xuYDtcclxuY29uc3QgUGxhbk9mZmVyaW5nU2tlbGV0b24gPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMjBweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQucGxhblBhZGRpbmd9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyfTtcbiAgbWluLXdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLmxheW91dC5wbGFuTWluV2lkdGh9O1xuICBtYXgtd2lkdGg6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXhXaWR0aH07XG4gIG1pbi1oZWlnaHQ6IDQ1MHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5gO1xyXG5jb25zdCBQbGFuc0NvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cubGF5b3V0LnBsYW5NYXJnaW59O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuYDtcclxuY29uc3QgRW50aXRsZW1lbnRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luLWJvdHRvbTogMTJweDtcbmA7XHJcbmNvbnN0IEZvb3RlclNrZWxldG9uTG9hZGVyID0gc3R5bGVkLmRpdiBgXG4gIG1hcmdpbi10b3A6IGF1dG87XG5gO1xyXG5jb25zdCBCaWxsaW5nUGVyaW9kTG9hZGVyID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxNTBweDtcbiAgbWFyZ2luLWJvdHRvbTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5sYXlvdXQuc3dpdGNoQm90dG9tU3BhY2luZ307XG4gIHBhZGRpbmc6IDEycHggMTJweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogd2hpdGU7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcbmA7XHJcbmZ1bmN0aW9uIFBsYW5PZmZlcmluZ0xvYWRlcigpIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmdTa2VsZXRvbiwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IGNpcmNsZTogdHJ1ZSwgd2lkdGg6IDQwLCBoZWlnaHQ6IDQwIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgc3R5bGU6IHsgbWFyZ2luQm90dG9tOiAzMyB9LCB3aWR0aDogMTIwLCBib3JkZXJSYWRpdXM6IDQgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFbnRpdGxlbWVudENoZWNrSWNvbiwgbnVsbCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCwgYm9yZGVyUmFkaXVzOiA0IH0pKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEVudGl0bGVtZW50Q2hlY2tJY29uLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogMTIwLCBib3JkZXJSYWRpdXM6IDQgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRW50aXRsZW1lbnRDaGVja0ljb24sIG51bGwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAsIGJvcmRlclJhZGl1czogNCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChGb290ZXJTa2VsZXRvbkxvYWRlciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyBoZWlnaHQ6IDUwLCBib3JkZXJSYWRpdXM6IDQgfSkpKSk7XHJcbn1cclxuZXhwb3J0IGZ1bmN0aW9uIFBheXdhbGxMb2FkZXIoKSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25Db250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXNrZWxldG9uLWxvYWRlci1jb250YWluZXJcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmlsbGluZ1BlcmlvZExvYWRlciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2tlbGV0b24tbG9hZGVyLWJpbGxpbmctcGVyaW9kXCIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyBib3JkZXJSYWRpdXM6IDQgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXNrZWxldG9uLWxvYWRlci1wbGFucy1jb250YWluZXJcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5PZmZlcmluZ0xvYWRlciwgbnVsbCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhbk9mZmVyaW5nTG9hZGVyLCBudWxsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuT2ZmZXJpbmdMb2FkZXIsIG51bGwpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBheXdhbGxMb2FkZXIuanMubWFwIl19 */",
|
|
3005
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3310
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
3006
3311
|
});
|
|
3007
3312
|
|
|
3008
3313
|
var BillingPeriodLoader = /*#__PURE__*/_styled("div", {
|
|
@@ -3546,7 +3851,7 @@ function Promotions() {
|
|
|
3546
3851
|
})));
|
|
3547
3852
|
}
|
|
3548
3853
|
|
|
3549
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3854
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$8() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
3550
3855
|
var StyledTabs = /*#__PURE__*/_styled(Tabs, {
|
|
3551
3856
|
target: "exlfw3j3",
|
|
3552
3857
|
label: "StyledTabs"
|
|
@@ -3554,7 +3859,7 @@ var StyledTabs = /*#__PURE__*/_styled(Tabs, {
|
|
|
3554
3859
|
name: "jlwfj4",
|
|
3555
3860
|
styles: ".MuiTabs-indicator{background-color:#001e6c;}",
|
|
3556
3861
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvblRhYnMuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJTdWJzY3JpcHRpb25UYWJzLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmltcG9ydCBUYWJzIGZyb20gJ0BtdWkvbWF0ZXJpYWwvVGFicyc7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUYWJzID0gc3R5bGVkKFRhYnMpIGBcbiAgLk11aVRhYnMtaW5kaWNhdG9yIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjMDAxZTZjO1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgVGFic0xheW91dCA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZmxleDogMTtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBtYXJnaW4tdG9wOiAxNnB4O1xuICBtYXgtaGVpZ2h0OiAkeyh7ICRtYXhIZWlnaHQgfSkgPT4gJG1heEhlaWdodH07XG4gIG92ZXJmbG93LXk6IGF1dG87XG5gO1xyXG5leHBvcnQgY29uc3QgTGlzdEJveCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBwYWRkaW5nOiAyNHB4O1xuICBib3JkZXI6ICR7KHsgJGJvcmRlckNvbG9yIH0pID0+IGAxcHggc29saWQgJHskYm9yZGVyQ29sb3J9YH07XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIG1hcmdpbi1ib3R0b206IDE2cHg7XG4gIHJvdy1nYXA6IDE2cHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgJGJhY2tncm91bmRDb2xvciB9KSA9PiAkYmFja2dyb3VuZENvbG9yfTtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVN1YnNjcmlwdGlvblRhYnMuc3R5bGUuanMubWFwIl19 */",
|
|
3557
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3862
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
3558
3863
|
});
|
|
3559
3864
|
var TabsLayout = /*#__PURE__*/_styled("div", {
|
|
3560
3865
|
target: "exlfw3j2",
|
|
@@ -3563,7 +3868,7 @@ var TabsLayout = /*#__PURE__*/_styled("div", {
|
|
|
3563
3868
|
name: "1dqkbz0",
|
|
3564
3869
|
styles: "width:100%;flex:1;margin-top:16px",
|
|
3565
3870
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvblRhYnMuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFxQyIsImZpbGUiOiJTdWJzY3JpcHRpb25UYWJzLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmltcG9ydCBUYWJzIGZyb20gJ0BtdWkvbWF0ZXJpYWwvVGFicyc7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUYWJzID0gc3R5bGVkKFRhYnMpIGBcbiAgLk11aVRhYnMtaW5kaWNhdG9yIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjMDAxZTZjO1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgVGFic0xheW91dCA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZmxleDogMTtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBtYXJnaW4tdG9wOiAxNnB4O1xuICBtYXgtaGVpZ2h0OiAkeyh7ICRtYXhIZWlnaHQgfSkgPT4gJG1heEhlaWdodH07XG4gIG92ZXJmbG93LXk6IGF1dG87XG5gO1xyXG5leHBvcnQgY29uc3QgTGlzdEJveCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBwYWRkaW5nOiAyNHB4O1xuICBib3JkZXI6ICR7KHsgJGJvcmRlckNvbG9yIH0pID0+IGAxcHggc29saWQgJHskYm9yZGVyQ29sb3J9YH07XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIG1hcmdpbi1ib3R0b206IDE2cHg7XG4gIHJvdy1nYXA6IDE2cHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgJGJhY2tncm91bmRDb2xvciB9KSA9PiAkYmFja2dyb3VuZENvbG9yfTtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVN1YnNjcmlwdGlvblRhYnMuc3R5bGUuanMubWFwIl19 */",
|
|
3566
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
3871
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
3567
3872
|
});
|
|
3568
3873
|
var TabContent = /*#__PURE__*/_styled(Box, {
|
|
3569
3874
|
target: "exlfw3j1",
|
|
@@ -3985,7 +4290,7 @@ function SubscriptionTabs(_ref2) {
|
|
|
3985
4290
|
}, React__default.createElement(Promotions, null)));
|
|
3986
4291
|
}
|
|
3987
4292
|
|
|
3988
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4293
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
3989
4294
|
|
|
3990
4295
|
var SkeletonLayout = /*#__PURE__*/_styled("div", {
|
|
3991
4296
|
target: "ejq3grd1",
|
|
@@ -3994,7 +4299,7 @@ var SkeletonLayout = /*#__PURE__*/_styled("div", {
|
|
|
3994
4299
|
name: "1eoy87d",
|
|
3995
4300
|
styles: "display:flex;justify-content:space-between",
|
|
3996
4301
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbk92ZXJ2aWV3TG9hZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHa0MiLCJmaWxlIjoiU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgU2tlbGV0b24gZnJvbSAncmVhY3QtbG9hZGluZy1za2VsZXRvbic7XHJcbmNvbnN0IFNrZWxldG9uTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IFNrZWxldG9uTGF5b3V0TGVmdCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDMycHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIoKSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXQsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi1vdmVydmlldy1za2VsZXRvbi1sYXlvdXRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXRMZWZ0LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogMjk1LCBoZWlnaHQ6IDE5MyB9KSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVN1YnNjcmlwdGlvbk92ZXJ2aWV3TG9hZGVyLmpzLm1hcCJdfQ== */",
|
|
3997
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4302
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
3998
4303
|
});
|
|
3999
4304
|
|
|
4000
4305
|
var SkeletonLayoutLeft = /*#__PURE__*/_styled("div", {
|
|
@@ -4004,7 +4309,7 @@ var SkeletonLayoutLeft = /*#__PURE__*/_styled("div", {
|
|
|
4004
4309
|
name: "43cxha",
|
|
4005
4310
|
styles: "display:flex;flex-direction:column;gap:32px",
|
|
4006
4311
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbk92ZXJ2aWV3TG9hZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPc0MiLCJmaWxlIjoiU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgU2tlbGV0b24gZnJvbSAncmVhY3QtbG9hZGluZy1za2VsZXRvbic7XHJcbmNvbnN0IFNrZWxldG9uTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IFNrZWxldG9uTGF5b3V0TGVmdCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDMycHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIoKSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXQsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi1vdmVydmlldy1za2VsZXRvbi1sYXlvdXRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXRMZWZ0LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogMjk1LCBoZWlnaHQ6IDE5MyB9KSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVN1YnNjcmlwdGlvbk92ZXJ2aWV3TG9hZGVyLmpzLm1hcCJdfQ== */",
|
|
4007
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4312
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
4008
4313
|
});
|
|
4009
4314
|
|
|
4010
4315
|
function SubscriptionOverviewLoader() {
|
|
@@ -4127,7 +4432,7 @@ function SubscriptionScheduledUpdateRow(_ref5) {
|
|
|
4127
4432
|
}
|
|
4128
4433
|
}
|
|
4129
4434
|
|
|
4130
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4435
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$a() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
4131
4436
|
|
|
4132
4437
|
var SubscriptionScheduleUpdateAlertContainer = /*#__PURE__*/_styled(material.Box, {
|
|
4133
4438
|
target: "eju957a2",
|
|
@@ -4144,7 +4449,7 @@ var LoadingIndicator$1 = /*#__PURE__*/_styled(ClipLoader, {
|
|
|
4144
4449
|
name: "158icaa",
|
|
4145
4450
|
styles: "margin-left:4px",
|
|
4146
4451
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvblNjaGVkdWxlZFVwZGF0ZXNBbGVydC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0I0QyIsImZpbGUiOiJTdWJzY3JpcHRpb25TY2hlZHVsZWRVcGRhdGVzQWxlcnQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBCb3gsIEdyaWQgfSBmcm9tICdAbXVpL21hdGVyaWFsJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IENsaXBMb2FkZXIgZnJvbSAncmVhY3Qtc3Bpbm5lcnMvQ2xpcExvYWRlcic7XHJcbmltcG9ydCBSZXN0b3JlIGZyb20gJy4uLy4uLy4uLy4uL2Fzc2V0cy9yZXN0b3JlLnN2Zyc7XHJcbmltcG9ydCB7IEljb24gfSBmcm9tICcuLi8uLi8uLi9jb21tb24vSWNvbic7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvblNjaGVkdWxlZFVwZGF0ZVJvdyB9IGZyb20gJy4vU3Vic2NyaXB0aW9uU2NoZWR1bGVkVXBkYXRlUm93JztcclxuaW1wb3J0IHsgZ2V0U3Vic2NyaXB0aW9uU2NoZWR1bGVVcGRhdGVUZXh0cyB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL2dldFN1YnNjcmlwdGlvblNjaGVkdWxlVXBkYXRlVGV4dHMnO1xyXG5pbXBvcnQgeyBTdHlsZWRCdXR0b24gfSBmcm9tICcuLi8uLi9jb21tb24vU3R5bGVkQnV0dG9uJztcclxuY29uc3QgU3Vic2NyaXB0aW9uU2NoZWR1bGVVcGRhdGVBbGVydENvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgYm9yZGVyLWJvdHRvbTogJHsoeyAkYm9yZGVyQ29sb3IgfSkgPT4gYDFweCBzb2xpZCAkeyRib3JkZXJDb2xvcn1gfTtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMTBweDtcbiAgYm9yZGVyLXRvcC1yaWdodC1yYWRpdXM6IDEwcHg7XG4gIG1hcmdpbjogLTY0cHggLTY0cHggNjRweCAtNjRweDtcbiAgcGFkZGluZzogMjRweCAzMnB4O1xuYDtcclxuY29uc3QgTG9hZGluZ0luZGljYXRvciA9IHN0eWxlZChDbGlwTG9hZGVyKSBgXG4gIG1hcmdpbi1sZWZ0OiA0cHg7XG5gO1xyXG5jb25zdCBTdHlsZWRSZXN0b3JlSWNvbiA9IHN0eWxlZChSZXN0b3JlKSBgXG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX07XG4gIHBhdGgge1xuICAgIGZpbGw6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5wcmltYXJ5fTtcbiAgfVxuYDtcclxuZnVuY3Rpb24gTXVsdGlwbGVTY2hlZHVsZWRVcGRhdGVzKHsgc3Vic2NyaXB0aW9uIH0pIHtcclxuICAgIGNvbnN0IHsgc2NoZWR1bGVkVXBkYXRlcyB9ID0gc3Vic2NyaXB0aW9uO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBjb250YWluZXI6IHRydWUsIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsIGp1c3RpZnlDb250ZW50OiBcInNwYWNlLWJldHdlZW5cIiwgZ2FwOiAxIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgbnVsbCxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2NoZWR1bGVkLXVwZGF0ZXMtZGVzY3JpcHRpb25cIiwgdmFyaWFudDogXCJib2R5MVwiIH0sIFwiVGhlIGZvbGxvd2luZyB1cGRhdGVzIHdpbGwgdGFrZSBlZmZlY3QgaW4gdGhlIG5leHQgYmlsbGluZyBjeWNsZTpcIikpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIG51bGwsIChzY2hlZHVsZWRVcGRhdGVzIHx8IFtdKS5tYXAoc2NoZWR1bGVVcGRhdGUgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3Vic2NyaXB0aW9uU2NoZWR1bGVkVXBkYXRlUm93LCB7IGtleTogc2NoZWR1bGVVcGRhdGUuc3Vic2NyaXB0aW9uU2NoZWR1bGVUeXBlLCBzY2hlZHVsZVVwZGF0ZTogc2NoZWR1bGVVcGRhdGUsIHN1YnNjcmlwdGlvbjogc3Vic2NyaXB0aW9uIH0pKSkpKSk7XHJcbn1cclxuZnVuY3Rpb24gU2luZ2xlU2NoZWR1bGVkVXBkYXRlKHsgc3Vic2NyaXB0aW9uIH0pIHtcclxuICAgIGNvbnN0IHsgc2NoZWR1bGVkVXBkYXRlcyB9ID0gc3Vic2NyaXB0aW9uO1xyXG4gICAgY29uc3QgW3NjaGVkdWxlZFVwZGF0ZV0gPSBzY2hlZHVsZWRVcGRhdGVzIHx8IFtdO1xyXG4gICAgY29uc3QgeyBsaW5lMSwgbGluZTIgfSA9IGdldFN1YnNjcmlwdGlvblNjaGVkdWxlVXBkYXRlVGV4dHMoe1xyXG4gICAgICAgIHNjaGVkdWxlZFVwZGF0ZSxcclxuICAgICAgICBzdWJzY3JpcHRpb25QcmljZXM6IHN1YnNjcmlwdGlvbi5wcmljZXMsXHJcbiAgICAgICAgYmlsbGluZ1BlcmlvZFJhbmdlOiBzdWJzY3JpcHRpb24uYmlsbGluZ1BlcmlvZFJhbmdlLFxyXG4gICAgICAgIG9wdGlvbnM6IHtcclxuICAgICAgICAgICAgcG9zdGZpeDogJ2F0IHRoZSBlbmQgb2YgdGhlIGN1cnJlbnQgYmlsbGluZyBwZXJpb2QnLFxyXG4gICAgICAgIH0sXHJcbiAgICB9KTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgY29udGFpbmVyOiB0cnVlLCBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLCBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsIGdhcDogMSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIG51bGwsXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLXNjaGVkdWxlZC11cGRhdGVzLXRpdGxlXCIsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwicHJpbWFyeVwiIH0sIGxpbmUxKSkpLFxyXG4gICAgICAgIGxpbmUyICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc2NoZWR1bGVkLXVwZGF0ZXMtc3VidGl0bGVcIiwgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBsaW5lMikpKSkpO1xyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBTdWJzY3JpcHRpb25TY2hlZHVsZWRVcGRhdGVzQWxlcnQoeyBzdWJzY3JpcHRpb24sIG9uQ2FuY2VsU2NoZWR1bGVkVXBkYXRlcywgdGhlbWUsIGNhbmNlbFNjaGVkdWxlZFVwZGF0ZXNCdXR0b25UaXRsZSwgfSkge1xyXG4gICAgY29uc3Qgc3RpZ2dUaGVtZSA9IHVzZVRoZW1lKCk7XHJcbiAgICBjb25zdCBbaXNMb2FkaW5nLCBzZXRJc0xvYWRpbmddID0gdXNlU3RhdGUoZmFsc2UpO1xyXG4gICAgY29uc3QgeyBzY2hlZHVsZWRVcGRhdGVzIH0gPSBzdWJzY3JpcHRpb247XHJcbiAgICBpZiAoIXNjaGVkdWxlZFVwZGF0ZXMgfHwgc2NoZWR1bGVkVXBkYXRlcy5sZW5ndGggPT09IDApIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIGNvbnN0IGlzU2luZ2xlU2NoZWR1bGVkVXBkYXRlID0gc2NoZWR1bGVkVXBkYXRlcy5sZW5ndGggPT09IDE7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3Vic2NyaXB0aW9uU2NoZWR1bGVVcGRhdGVBbGVydENvbnRhaW5lciwgeyBcIiRib3JkZXJDb2xvclwiOiB0aGVtZS5ib3JkZXJDb2xvciwgY2xhc3NOYW1lOiBcInN0aWdnLXNjaGVkdWxlZC11cGRhdGVzLWFsZXJ0LWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGNvbnRhaW5lcjogdHJ1ZSwgYWxpZ25JdGVtczogaXNTaW5nbGVTY2hlZHVsZWRVcGRhdGUgPyAnY2VudGVyJyA6ICdmbGV4LXN0YXJ0JywgZ2FwOiAyIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlLCBkaXNwbGF5OiBcImZsZXhcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJY29uLCB7IGljb246ICdTY2hlZHVsZUJveCcsIHN2Z1BhdGhDb2xvcjogdGhlbWUuaWNvbnNDb2xvciwgc3ZnUmVjdENvbG9yOiB0aGVtZS5pY29uc0JhY2tncm91bmRDb2xvciB9KSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlLCBmbGV4OiAxIH0sIGlzU2luZ2xlU2NoZWR1bGVkVXBkYXRlID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2luZ2xlU2NoZWR1bGVkVXBkYXRlLCB7IHN1YnNjcmlwdGlvbjogc3Vic2NyaXB0aW9uIH0pKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KE11bHRpcGxlU2NoZWR1bGVkVXBkYXRlcywgeyBzdWJzY3JpcHRpb246IHN1YnNjcmlwdGlvbiB9KSkpLFxyXG4gICAgICAgICAgICAhIW9uQ2FuY2VsU2NoZWR1bGVkVXBkYXRlcyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQnV0dG9uLCB7IHZhcmlhbnQ6IFwib3V0bGluZWRcIiwgb25DbGljazogKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBzZXRJc0xvYWRpbmcodHJ1ZSk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFByb21pc2UucmVzb2x2ZShvbkNhbmNlbFNjaGVkdWxlZFVwZGF0ZXMoc3Vic2NyaXB0aW9uKSkuZmluYWxseSgoKSA9PiBzZXRJc0xvYWRpbmcoZmFsc2UpKTtcclxuICAgICAgICAgICAgICAgICAgICB9IH0sXHJcbiAgICAgICAgICAgICAgICAgICAgaXNMb2FkaW5nID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9hZGluZ0luZGljYXRvciwgeyBsb2FkaW5nOiB0cnVlLCBzaXplOiAxNiwgY29sb3I6IHN0aWdnVGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LmRpc2FibGVkIH0pKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFJlc3RvcmVJY29uLCB7IHN0eWxlOiB7IGRpc3BsYXk6ICdmbGV4JywgbWFyZ2luUmlnaHQ6IDQgfSwgY2xhc3NOYW1lOiBcInN0aWdnLXNjaGVkdWxlZC11cGRhdGVzLWNhbmNlbC11cGRhdGUtYnV0dG9uLWljb25cIiB9KSksXHJcbiAgICAgICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwicHJpbWFyeS5tYWluXCIsIGNsYXNzTmFtZTogXCJzdGlnZy1zY2hlZHVsZWQtdXBkYXRlcy1jYW5jZWwtdXBkYXRlLWJ1dHRvblwiIH0sIGNhbmNlbFNjaGVkdWxlZFVwZGF0ZXNCdXR0b25UaXRsZSkpKSkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9U3Vic2NyaXB0aW9uU2NoZWR1bGVkVXBkYXRlc0FsZXJ0LmpzLm1hcCJdfQ== */",
|
|
4147
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4452
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$a
|
|
4148
4453
|
});
|
|
4149
4454
|
|
|
4150
4455
|
var StyledRestoreIcon = /*#__PURE__*/_styled(SvgRestore, {
|
|
@@ -4326,7 +4631,7 @@ function NoUpcomingBilling(_ref) {
|
|
|
4326
4631
|
}, description));
|
|
4327
4632
|
}
|
|
4328
4633
|
|
|
4329
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4634
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$b() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
4330
4635
|
|
|
4331
4636
|
var ContactCustomerSupportLayout = /*#__PURE__*/_styled("div", {
|
|
4332
4637
|
target: "e1ftdtst1",
|
|
@@ -4335,7 +4640,7 @@ var ContactCustomerSupportLayout = /*#__PURE__*/_styled("div", {
|
|
|
4335
4640
|
name: "1nocm2b",
|
|
4336
4641
|
styles: "display:flex;flex-direction:column;align-items:left;gap:8px",
|
|
4337
4642
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbnRhY3RDdXN0b21lclN1cHBvcnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlnRCIsImZpbGUiOiJDb250YWN0Q3VzdG9tZXJTdXBwb3J0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbXVpL21hdGVyaWFsL0J1dHRvbic7XHJcbmNvbnN0IENvbnRhY3RDdXN0b21lclN1cHBvcnRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGxlZnQ7XG4gIGdhcDogOHB4O1xuYDtcclxuY29uc3QgQ29udGFjdFN1cHBvcnRCdXR0b24gPSBzdHlsZWQoQnV0dG9uKSBgXG4gIHdpZHRoOiBmaXQtY29udGVudDtcbiAgJi5NdWlCdXR0b24tcm9vdCB7XG4gICAgcGFkZGluZzogMDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gQ29udGFjdEN1c3RvbWVyU3VwcG9ydCh7IG9uQ29udGFjdFN1cHBvcnQsIGxhYmVsLCBsaW5rTGFiZWwgfSkge1xyXG4gICAgbGV0IGNvbnRhY3RTdXBwb3J0VGV4dCA9IFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogb25Db250YWN0U3VwcG9ydCA/ICdwcmltYXJ5Lm1haW4nIDogJ3NlY29uZGFyeScgfSwgbGlua0xhYmVsKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDb250YWN0Q3VzdG9tZXJTdXBwb3J0TGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jb250YWN0LXN1cHBvcnQtbGF5b3V0XCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNvbnRhY3Qtc3VwcG9ydC1sYWJlbFwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBsYWJlbCksXHJcbiAgICAgICAgb25Db250YWN0U3VwcG9ydCA/IChSZWFjdC5jcmVhdGVFbGVtZW50KENvbnRhY3RTdXBwb3J0QnV0dG9uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jb250YWN0LXN1cHBvcnQtYnV0dG9uXCIsIHN0eWxlOiB7IHRleHRUcmFuc2Zvcm06ICdub25lJyB9LCB2YXJpYW50OiBcInRleHRcIiwgb25DbGljazogb25Db250YWN0U3VwcG9ydCB9LCBjb250YWN0U3VwcG9ydFRleHQpKSA6IChjb250YWN0U3VwcG9ydFRleHQpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q29udGFjdEN1c3RvbWVyU3VwcG9ydC5qcy5tYXAiXX0= */",
|
|
4338
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4643
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$b
|
|
4339
4644
|
});
|
|
4340
4645
|
|
|
4341
4646
|
var ContactSupportButton = /*#__PURE__*/_styled(Button, {
|
|
@@ -4345,7 +4650,7 @@ var ContactSupportButton = /*#__PURE__*/_styled(Button, {
|
|
|
4345
4650
|
name: "1l28f5r",
|
|
4346
4651
|
styles: "width:fit-content;&.MuiButton-root{padding:0;&:hover{background:none;}}",
|
|
4347
4652
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbnRhY3RDdXN0b21lclN1cHBvcnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVU0QyIsImZpbGUiOiJDb250YWN0Q3VzdG9tZXJTdXBwb3J0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbXVpL21hdGVyaWFsL0J1dHRvbic7XHJcbmNvbnN0IENvbnRhY3RDdXN0b21lclN1cHBvcnRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGxlZnQ7XG4gIGdhcDogOHB4O1xuYDtcclxuY29uc3QgQ29udGFjdFN1cHBvcnRCdXR0b24gPSBzdHlsZWQoQnV0dG9uKSBgXG4gIHdpZHRoOiBmaXQtY29udGVudDtcbiAgJi5NdWlCdXR0b24tcm9vdCB7XG4gICAgcGFkZGluZzogMDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gQ29udGFjdEN1c3RvbWVyU3VwcG9ydCh7IG9uQ29udGFjdFN1cHBvcnQsIGxhYmVsLCBsaW5rTGFiZWwgfSkge1xyXG4gICAgbGV0IGNvbnRhY3RTdXBwb3J0VGV4dCA9IFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogb25Db250YWN0U3VwcG9ydCA/ICdwcmltYXJ5Lm1haW4nIDogJ3NlY29uZGFyeScgfSwgbGlua0xhYmVsKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDb250YWN0Q3VzdG9tZXJTdXBwb3J0TGF5b3V0LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jb250YWN0LXN1cHBvcnQtbGF5b3V0XCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNvbnRhY3Qtc3VwcG9ydC1sYWJlbFwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBsYWJlbCksXHJcbiAgICAgICAgb25Db250YWN0U3VwcG9ydCA/IChSZWFjdC5jcmVhdGVFbGVtZW50KENvbnRhY3RTdXBwb3J0QnV0dG9uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jb250YWN0LXN1cHBvcnQtYnV0dG9uXCIsIHN0eWxlOiB7IHRleHRUcmFuc2Zvcm06ICdub25lJyB9LCB2YXJpYW50OiBcInRleHRcIiwgb25DbGljazogb25Db250YWN0U3VwcG9ydCB9LCBjb250YWN0U3VwcG9ydFRleHQpKSA6IChjb250YWN0U3VwcG9ydFRleHQpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q29udGFjdEN1c3RvbWVyU3VwcG9ydC5qcy5tYXAiXX0= */",
|
|
4348
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4653
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$b
|
|
4349
4654
|
});
|
|
4350
4655
|
|
|
4351
4656
|
function ContactCustomerSupport(_ref) {
|
|
@@ -4573,7 +4878,7 @@ var LongText = function LongText(_ref5) {
|
|
|
4573
4878
|
}, content) : content);
|
|
4574
4879
|
};
|
|
4575
4880
|
|
|
4576
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4881
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$c() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
4577
4882
|
|
|
4578
4883
|
var OnTrialBadge = /*#__PURE__*/_styled("div", {
|
|
4579
4884
|
target: "el5iwyw1",
|
|
@@ -4590,7 +4895,7 @@ var StyledLink = /*#__PURE__*/_styled(material.Link, {
|
|
|
4590
4895
|
name: "69ka7t",
|
|
4591
4896
|
styles: "text-decoration-color:white;color:white;cursor:pointer",
|
|
4592
4897
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiVHJpYWxQYW5lbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBTYW5kQ2xvY2tJY29uIGZyb20gJy4uLy4uLy4uLy4uL2Fzc2V0cy9zYW5kLWNsb2NrLnN2Zyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvblN0YXR1cyB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IHsgTGluayB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBMb25nVGV4dCB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9Mb25nVGV4dCc7XHJcbmNvbnN0IE9uVHJpYWxCYWRnZSA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiA0cHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS53YXJuaW5nfTtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgcGFkZGluZzogOHB4IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5jb25zdCBTdHlsZWRMaW5rID0gc3R5bGVkKExpbmspIGBcbiAgdGV4dC1kZWNvcmF0aW9uLWNvbG9yOiB3aGl0ZTtcbiAgY29sb3I6IHdoaXRlO1xuICBjdXJzb3I6IHBvaW50ZXI7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVHJpYWxQYW5lbCh7IHN1YnNjcmlwdGlvbiwgaW5jbHVkZVBsYW5OYW1lLCBvbk1hbmFnZVN1YnNjcmlwdGlvbiwgfSkge1xyXG4gICAgaWYgKHN1YnNjcmlwdGlvbj8uc3RhdHVzICE9PSBTdWJzY3JpcHRpb25TdGF0dXMuSW5UcmlhbCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KE9uVHJpYWxCYWRnZSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlXCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNhbmRDbG9ja0ljb24sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC1iYWRnZS1pbWFnZVwiIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyBzdHlsZTogeyBmbGV4OiAxLCBtYXJnaW5SaWdodDogNCB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9uZ1RleHQsIHsgdmFyaWFudDogXCJib2R5MVwiLCBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLXRleHRcIiwgY29sb3I6IFwid2hpdGVcIiB9LFxyXG4gICAgICAgICAgICAgICAgYCR7c3Vic2NyaXB0aW9uLnRyaWFsUmVtYWluaW5nRGF5c30gZGF5cyByZW1haW5pbmcgaW4gdHJpYWxgLFxyXG4gICAgICAgICAgICAgICAgaW5jbHVkZVBsYW5OYW1lICYmIGAgb2YgdGhlICR7c3Vic2NyaXB0aW9uLnBsYW5OYW1lfSBwbGFuYCkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGluaywgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLXVwZ3JhZGUtYnV0dG9uXCIsIG9uQ2xpY2s6IG9uTWFuYWdlU3Vic2NyaXB0aW9uIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJ3aGl0ZVwiIH0sIFwiVXBncmFkZSBwbGFuXCIpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyaWFsUGFuZWwuanMubWFwIl19 */",
|
|
4593
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
4898
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$c
|
|
4594
4899
|
});
|
|
4595
4900
|
|
|
4596
4901
|
function TrialPanel(_ref2) {
|
|
@@ -4986,7 +5291,7 @@ function SubscriptionsOverview(_ref) {
|
|
|
4986
5291
|
}))));
|
|
4987
5292
|
}
|
|
4988
5293
|
|
|
4989
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5294
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$d() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
4990
5295
|
|
|
4991
5296
|
var CustomerPortalHeaderLayout = /*#__PURE__*/_styled("div", {
|
|
4992
5297
|
target: "e2lw8x70",
|
|
@@ -4995,7 +5300,7 @@ var CustomerPortalHeaderLayout = /*#__PURE__*/_styled("div", {
|
|
|
4995
5300
|
name: "7wpci2",
|
|
4996
5301
|
styles: "display:flex;width:100%;align-items:flex-end;justify-content:flex-end;margin-bottom:24px",
|
|
4997
5302
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkN1c3RvbWVyUG9ydGFsSGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHOEMiLCJmaWxlIjoiQ3VzdG9tZXJQb3J0YWxIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBQb3dlcmVkQnlTdGlnZyB9IGZyb20gJy4uL2NvbW1vbi9Qb3dlcmVkQnlTdGlnZyc7XHJcbmNvbnN0IEN1c3RvbWVyUG9ydGFsSGVhZGVyTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHdpZHRoOiAxMDAlO1xuICBhbGlnbi1pdGVtczogZmxleC1lbmQ7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIG1hcmdpbi1ib3R0b206IDI0cHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gQ3VzdG9tZXJQb3J0YWxIZWFkZXIoeyBzaG93V2F0ZXJtYXJrIH0pIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDdXN0b21lclBvcnRhbEhlYWRlckxheW91dCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY3VzdG9tZXItcG9ydGFsLWhlYWRlci1sYXlvdXRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUG93ZXJlZEJ5U3RpZ2csIHsgc291cmNlOiBcImN1c3RvbWVyX3BvcnRhbFwiLCBzaG93V2F0ZXJtYXJrOiBzaG93V2F0ZXJtYXJrIH0pKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q3VzdG9tZXJQb3J0YWxIZWFkZXIuanMubWFwIl19 */",
|
|
4998
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5303
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$d
|
|
4999
5304
|
});
|
|
5000
5305
|
|
|
5001
5306
|
function CustomerPortalHeader(_ref) {
|
|
@@ -5008,7 +5313,7 @@ function CustomerPortalHeader(_ref) {
|
|
|
5008
5313
|
}));
|
|
5009
5314
|
}
|
|
5010
5315
|
|
|
5011
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5316
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$e() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
5012
5317
|
|
|
5013
5318
|
var ExternalLinkText = /*#__PURE__*/_styled(Typography, {
|
|
5014
5319
|
target: "eb0pe7a1",
|
|
@@ -5017,7 +5322,7 @@ var ExternalLinkText = /*#__PURE__*/_styled(Typography, {
|
|
|
5017
5322
|
name: "kxbue8",
|
|
5018
5323
|
styles: "text-transform:none",
|
|
5019
5324
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkV4dGVybmFsTGlua0J1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSzRDIiwiZmlsZSI6IkV4dGVybmFsTGlua0J1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFN0eWxlZEJ1dHRvbiB9IGZyb20gJy4vU3R5bGVkQnV0dG9uJztcclxuaW1wb3J0IHsgRXh0ZXJuYWxMaW5rIGFzIEV4dGVybmFsTGlua0ljb24gfSBmcm9tICdyZWFjdC1mZWF0aGVyJztcclxuY29uc3QgRXh0ZXJuYWxMaW5rVGV4dCA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHRleHQtdHJhbnNmb3JtOiBub25lO1xuYDtcclxuY29uc3QgTGlua0ljb24gPSBzdHlsZWQoRXh0ZXJuYWxMaW5rSWNvbikgYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnByaW1hcnl9O1xuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIEV4dGVybmFsTGlua0J1dHRvbih7IHRleHQsIHVybCwgY2xhc3NOYW1lIH0pIHtcclxuICAgIGNvbnN0IG9uQ2xpY2sgPSAoKSA9PiB7XHJcbiAgICAgICAgd2luZG93Lm9wZW4odXJsLCAnX2JsYW5rJyk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEJ1dHRvbiwgeyBjbGFzc05hbWU6IGNsYXNzTmFtZSwgdmFyaWFudDogXCJvdXRsaW5lZFwiLCBzdGFydEljb246IFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGlua0ljb24sIHsgc2l6ZTogMjAsIHN0cm9rZVdpZHRoOiAyLjUgfSksIG9uQ2xpY2s6IG9uQ2xpY2sgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEV4dGVybmFsTGlua1RleHQsIHsgY29sb3I6IFwicHJpbWFyeS5tYWluXCIgfSwgdGV4dCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1FeHRlcm5hbExpbmtCdXR0b24uanMubWFwIl19 */",
|
|
5020
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5325
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$e
|
|
5021
5326
|
});
|
|
5022
5327
|
|
|
5023
5328
|
var LinkIcon = /*#__PURE__*/_styled(reactFeather.ExternalLink, {
|
|
@@ -5050,7 +5355,7 @@ function ExternalLinkButton(_ref2) {
|
|
|
5050
5355
|
}, text));
|
|
5051
5356
|
}
|
|
5052
5357
|
|
|
5053
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5358
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$f() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
5054
5359
|
var InformationGridContainer = /*#__PURE__*/_styled("div", {
|
|
5055
5360
|
target: "e12mjvl51",
|
|
5056
5361
|
label: "InformationGridContainer"
|
|
@@ -5058,7 +5363,7 @@ var InformationGridContainer = /*#__PURE__*/_styled("div", {
|
|
|
5058
5363
|
name: "1hidw77",
|
|
5059
5364
|
styles: "display:flex;flex-direction:column;align-items:flex-start;gap:16px;flex:1 0 0",
|
|
5060
5365
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkluZm9ybWF0aW9uR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSW1EIiwiZmlsZSI6IkluZm9ybWF0aW9uR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEZvbnRXZWlnaHQgfSBmcm9tICdzdHlsZWQtdHlwb2dyYXBoeSc7XHJcbmV4cG9ydCBjb25zdCBJbmZvcm1hdGlvbkdyaWRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgZmxleDogMSAwIDA7XG5gO1xyXG5jb25zdCBJbmZvcm1hdGlvbkdyaWRSb3cgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgYWxpZ24tc2VsZjogc3RyZXRjaDtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBJbmZvcm1hdGlvbkdyaWQoeyB0aXRsZSwgcm93cyB9KSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5mb3JtYXRpb25HcmlkQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBmb250V2VpZ2h0OiBGb250V2VpZ2h0Lk1lZGl1bSB9LCB0aXRsZSksXHJcbiAgICAgICAgcm93cy5tYXAoKHsgY2xhc3NOYW1lUHJlZml4LCBsYWJlbCwgdmFsdWUsIGxhYmVsVHlwb2dyYXBoeVByb3BzLCB2YWx1ZVR5cG9ncmFwaHlQcm9wcyB9KSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbmZvcm1hdGlvbkdyaWRSb3csIHsga2V5OiBsYWJlbCB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIE9iamVjdC5hc3NpZ24oeyBjbGFzc05hbWU6IGAke2NsYXNzTmFtZVByZWZpeH0tbGFiZWxgLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBzdHlsZTogeyB3aWR0aDogODAgfSB9LCBsYWJlbFR5cG9ncmFwaHlQcm9wcyksIGxhYmVsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCBPYmplY3QuYXNzaWduKHsgY2xhc3NOYW1lOiBgJHtjbGFzc05hbWVQcmVmaXh9LXRleHRgLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHZhbHVlVHlwb2dyYXBoeVByb3BzKSwgdmFsdWUpKSkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9SW5mb3JtYXRpb25HcmlkLmpzLm1hcCJdfQ== */",
|
|
5061
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5366
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$f
|
|
5062
5367
|
});
|
|
5063
5368
|
|
|
5064
5369
|
var InformationGridRow = /*#__PURE__*/_styled("div", {
|
|
@@ -5068,7 +5373,7 @@ var InformationGridRow = /*#__PURE__*/_styled("div", {
|
|
|
5068
5373
|
name: "j9hhqa",
|
|
5069
5374
|
styles: "display:flex;align-items:flex-start;gap:16px;align-self:stretch",
|
|
5070
5375
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkluZm9ybWF0aW9uR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV3NDIiwiZmlsZSI6IkluZm9ybWF0aW9uR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEZvbnRXZWlnaHQgfSBmcm9tICdzdHlsZWQtdHlwb2dyYXBoeSc7XHJcbmV4cG9ydCBjb25zdCBJbmZvcm1hdGlvbkdyaWRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgZmxleDogMSAwIDA7XG5gO1xyXG5jb25zdCBJbmZvcm1hdGlvbkdyaWRSb3cgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgYWxpZ24tc2VsZjogc3RyZXRjaDtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBJbmZvcm1hdGlvbkdyaWQoeyB0aXRsZSwgcm93cyB9KSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5mb3JtYXRpb25HcmlkQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBmb250V2VpZ2h0OiBGb250V2VpZ2h0Lk1lZGl1bSB9LCB0aXRsZSksXHJcbiAgICAgICAgcm93cy5tYXAoKHsgY2xhc3NOYW1lUHJlZml4LCBsYWJlbCwgdmFsdWUsIGxhYmVsVHlwb2dyYXBoeVByb3BzLCB2YWx1ZVR5cG9ncmFwaHlQcm9wcyB9KSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbmZvcm1hdGlvbkdyaWRSb3csIHsga2V5OiBsYWJlbCB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIE9iamVjdC5hc3NpZ24oeyBjbGFzc05hbWU6IGAke2NsYXNzTmFtZVByZWZpeH0tbGFiZWxgLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBzdHlsZTogeyB3aWR0aDogODAgfSB9LCBsYWJlbFR5cG9ncmFwaHlQcm9wcyksIGxhYmVsKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCBPYmplY3QuYXNzaWduKHsgY2xhc3NOYW1lOiBgJHtjbGFzc05hbWVQcmVmaXh9LXRleHRgLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHZhbHVlVHlwb2dyYXBoeVByb3BzKSwgdmFsdWUpKSkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9SW5mb3JtYXRpb25HcmlkLmpzLm1hcCJdfQ== */",
|
|
5071
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5376
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$f
|
|
5072
5377
|
});
|
|
5073
5378
|
|
|
5074
5379
|
function InformationGrid(_ref) {
|
|
@@ -5252,7 +5557,7 @@ var CustomerPortalPaywall = /*#__PURE__*/React__default.forwardRef(function (_re
|
|
|
5252
5557
|
})), paywallComponent);
|
|
5253
5558
|
});
|
|
5254
5559
|
|
|
5255
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5560
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$g() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
5256
5561
|
|
|
5257
5562
|
var CustomerPortalLayout = /*#__PURE__*/_styled("div", {
|
|
5258
5563
|
target: "e1gjjeod1",
|
|
@@ -5261,7 +5566,7 @@ var CustomerPortalLayout = /*#__PURE__*/_styled("div", {
|
|
|
5261
5566
|
name: "6xtw2",
|
|
5262
5567
|
styles: "width:100%;display:flex;flex-direction:column;align-items:center;& *{box-sizing:border-box;}",
|
|
5263
5568
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkN1c3RvbWVyUG9ydGFsLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUMrQyIsImZpbGUiOiJDdXN0b21lclBvcnRhbC5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuZXhwb3J0IGNvbnN0IEN1c3RvbWVyUG9ydGFsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBcbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ3VzdG9tZXJQb3J0YWxTZWN0aW9ucyA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcm93LWdhcDogMjRweDtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUN1c3RvbWVyUG9ydGFsLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
5264
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5569
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$g
|
|
5265
5570
|
});
|
|
5266
5571
|
var CustomerPortalSections = /*#__PURE__*/_styled("div", {
|
|
5267
5572
|
target: "e1gjjeod0",
|
|
@@ -5270,7 +5575,7 @@ var CustomerPortalSections = /*#__PURE__*/_styled("div", {
|
|
|
5270
5575
|
name: "1c31jfu",
|
|
5271
5576
|
styles: "width:100%;display:flex;flex-direction:column;align-items:center;row-gap:24px",
|
|
5272
5577
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkN1c3RvbWVyUG9ydGFsLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVdpRCIsImZpbGUiOiJDdXN0b21lclBvcnRhbC5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuZXhwb3J0IGNvbnN0IEN1c3RvbWVyUG9ydGFsTGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBcbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ3VzdG9tZXJQb3J0YWxTZWN0aW9ucyA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcm93LWdhcDogMjRweDtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUN1c3RvbWVyUG9ydGFsLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
5273
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5578
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$g
|
|
5274
5579
|
});
|
|
5275
5580
|
|
|
5276
5581
|
function getFeatureDisplayName(feature) {
|
|
@@ -5361,7 +5666,7 @@ function FeatureUsage(_ref) {
|
|
|
5361
5666
|
}, "In current billing period"));
|
|
5362
5667
|
}
|
|
5363
5668
|
|
|
5364
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5669
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$h() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
5365
5670
|
var Footer = /*#__PURE__*/_styled("div", {
|
|
5366
5671
|
target: "eoaojje0",
|
|
5367
5672
|
label: "Footer"
|
|
@@ -5369,7 +5674,7 @@ var Footer = /*#__PURE__*/_styled("div", {
|
|
|
5369
5674
|
name: "3hgi0y",
|
|
5370
5675
|
styles: "margin-top:32px",
|
|
5371
5676
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkN1c3RvbWVyVXNhZ2VEYXRhLnN0eWxlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLaUMiLCJmaWxlIjoiQ3VzdG9tZXJVc2FnZURhdGEuc3R5bGUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBHcmlkIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmltcG9ydCB7IHJhbmdlIH0gZnJvbSAnbG9kYXNoJztcclxuaW1wb3J0IFNrZWxldG9uIGZyb20gJ3JlYWN0LWxvYWRpbmctc2tlbGV0b24nO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5leHBvcnQgY29uc3QgRm9vdGVyID0gc3R5bGVkLmRpdiBgXG4gIG1hcmdpbi10b3A6IDMycHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gQ3VzdG9tZXJVc2FnZUxvYWRlcigpIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGNvbnRhaW5lcjogdHJ1ZSwgc3BhY2luZzogNCwgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi11c2FnZS1za2VsZXRvbi1sYXlvdXRcIiB9LCByYW5nZSg2KS5tYXAoKGl0ZW0pID0+IChSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsga2V5OiBpdGVtLCBpdGVtOiB0cnVlLCB4czogNCB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDI4MCwgaGVpZ2h0OiAxMjAgfSkpKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DdXN0b21lclVzYWdlRGF0YS5zdHlsZS5qcy5tYXAiXX0= */",
|
|
5372
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
5677
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
|
|
5373
5678
|
});
|
|
5374
5679
|
function CustomerUsageLoader() {
|
|
5375
5680
|
return React__default.createElement(material.Grid, {
|