@stigg/react-sdk 4.14.0 → 5.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/customerPortal/CustomerPortal.d.ts +2 -2
- package/dist/components/customerPortal/CustomerPortalContainer.d.ts +4 -0
- package/dist/components/customerPortal/index.d.ts +3 -0
- package/dist/components/customerPortal/subscriptionOverview/SubscriptionsOverview.d.ts +2 -1
- package/dist/components/customerPortal/subscriptionOverview/SubscriptionsOverviewHeader.d.ts +2 -1
- package/dist/components/customerPortal/subscriptionOverview/charges/ChargeItem.d.ts +2 -1
- package/dist/components/customerPortal/subscriptionOverview/charges/ChargeList.d.ts +2 -1
- package/dist/components/customerPortal/subscriptionOverview/subscriptionView/SubscriptionView.d.ts +2 -1
- package/dist/components/customerPortal/subscriptionOverview/subscriptionView/TrialPanel.d.ts +2 -1
- package/dist/components/customerPortal/types.d.ts +10 -1
- package/dist/components/customerPortal/usage/CustomerUsageData.d.ts +2 -1
- package/dist/components/customerPortal/usage/featureUsage/EntitlementCTAButton.d.ts +2 -1
- package/dist/components/customerPortal/usage/featureUsage/FeatureUsage.d.ts +2 -1
- package/dist/components/paywall/index.d.ts +1 -1
- package/dist/components/paywall/paywallTextOverrides.d.ts +6 -1
- package/dist/components/utils/priceTierUtils.d.ts +3 -1
- package/dist/index.d.ts +3 -3
- package/dist/react-sdk.cjs.development.js +82 -55
- 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 +87 -58
- package/dist/react-sdk.esm.js.map +1 -1
- package/package.json +2 -2
- package/src/components/checkout/hooks/usePlanStepModel.ts +3 -3
- package/src/components/checkout/summary/components/LineItems.tsx +7 -3
- package/src/components/common/TiersSelectContainer.tsx +7 -14
- package/src/components/customerPortal/CustomerPortal.tsx +2 -2
- package/src/components/customerPortal/CustomerPortalContainer.tsx +8 -3
- package/src/components/customerPortal/index.ts +3 -0
- package/src/components/customerPortal/subscriptionOverview/SubscriptionsOverview.tsx +2 -1
- package/src/components/customerPortal/subscriptionOverview/SubscriptionsOverviewHeader.tsx +7 -2
- package/src/components/customerPortal/subscriptionOverview/charges/ChargeItem.tsx +2 -1
- package/src/components/customerPortal/subscriptionOverview/charges/ChargeList.tsx +2 -1
- package/src/components/customerPortal/subscriptionOverview/subscriptionView/SubscriptionView.tsx +2 -1
- package/src/components/customerPortal/subscriptionOverview/subscriptionView/TrialPanel.tsx +6 -2
- package/src/components/customerPortal/types.ts +15 -1
- package/src/components/customerPortal/usage/CustomerUsageData.tsx +2 -1
- package/src/components/customerPortal/usage/featureUsage/EntitlementCTAButton.tsx +6 -3
- package/src/components/customerPortal/usage/featureUsage/FeatureUsage.tsx +2 -1
- package/src/components/paywall/index.ts +1 -1
- package/src/components/utils/calculateDiscountRate.ts +2 -1
- package/src/components/utils/getPaidPriceText.ts +1 -1
- package/src/components/utils/priceTierUtils.ts +41 -21
- package/src/index.ts +9 -1
- package/src/stories/mocks/checkout/mockCheckoutState.ts +4 -4
|
@@ -746,18 +746,30 @@ function getTierByQuantity(tiers, quantity) {
|
|
|
746
746
|
|
|
747
747
|
return ascendingTiers[ascendingTiers.length - 1];
|
|
748
748
|
}
|
|
749
|
-
function calculateTierPrice(price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantity) {
|
|
750
|
-
var unitPrice = selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? currentTier.unitPrice.amount / 12 : currentTier.unitPrice.amount;
|
|
751
749
|
|
|
750
|
+
function getAmount(amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
751
|
+
return selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? amount / 12 : amount;
|
|
752
|
+
}
|
|
753
|
+
|
|
754
|
+
function calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
755
|
+
var amount = 0;
|
|
756
|
+
|
|
757
|
+
if (currentTier.unitPrice) {
|
|
758
|
+
var unitPrice = getAmount(currentTier.unitPrice.amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
759
|
+
amount += unitPrice * perUnitQuantity;
|
|
760
|
+
}
|
|
761
|
+
|
|
762
|
+
if (currentTier.flatPrice) {
|
|
763
|
+
amount += getAmount(currentTier.flatPrice.amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
764
|
+
}
|
|
765
|
+
|
|
766
|
+
return amount;
|
|
767
|
+
}
|
|
768
|
+
function calculateTierPrice(price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantity) {
|
|
752
769
|
switch (price.tiersMode) {
|
|
753
770
|
case Stigg.TiersMode.Volume:
|
|
754
771
|
{
|
|
755
|
-
return
|
|
756
|
-
}
|
|
757
|
-
|
|
758
|
-
case Stigg.TiersMode.VolumePerUnit:
|
|
759
|
-
{
|
|
760
|
-
return unitPrice * (perUnitQuantity || 1);
|
|
772
|
+
return calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
761
773
|
}
|
|
762
774
|
|
|
763
775
|
default:
|
|
@@ -791,6 +803,13 @@ function getSelectedTierQuantityBeFeature(plan, billingPeriod, currentSubscripti
|
|
|
791
803
|
|
|
792
804
|
return result;
|
|
793
805
|
}
|
|
806
|
+
function hasTierWithUnitPrice(tiers) {
|
|
807
|
+
return tiers == null ? void 0 : tiers.some(function (_ref) {
|
|
808
|
+
var unitPrice = _ref.unitPrice,
|
|
809
|
+
upTo = _ref.upTo;
|
|
810
|
+
return unitPrice && !isNil(upTo);
|
|
811
|
+
});
|
|
812
|
+
}
|
|
794
813
|
function getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature, selectDefaultTierIndex) {
|
|
795
814
|
var planTierPrices = plan.pricePoints.filter(function (price) {
|
|
796
815
|
return price.billingPeriod === billingPeriod && price.isTieredPrice;
|
|
@@ -853,7 +872,7 @@ function compareSelectedTierToCurrentTier(selectedTierByFeature, perUnitQuantity
|
|
|
853
872
|
var _currentTierPrice$fea = currentTierPrice.feature,
|
|
854
873
|
featureId = _currentTierPrice$fea.featureId,
|
|
855
874
|
unitQuantity = _currentTierPrice$fea.unitQuantity;
|
|
856
|
-
var
|
|
875
|
+
var tiers = currentTierPrice.tiers;
|
|
857
876
|
|
|
858
877
|
if (!unitQuantity) {
|
|
859
878
|
return PriceTierComparison.Equal;
|
|
@@ -866,20 +885,14 @@ function compareSelectedTierToCurrentTier(selectedTierByFeature, perUnitQuantity
|
|
|
866
885
|
return PriceTierComparison.Equal;
|
|
867
886
|
}
|
|
868
887
|
|
|
869
|
-
|
|
870
|
-
if (selectedTier.upTo && selectedTier.upTo < unitQuantity) {
|
|
871
|
-
return PriceTierComparison.Lower;
|
|
872
|
-
}
|
|
888
|
+
var effectiveQuantity = hasTierWithUnitPrice(tiers) ? selectedQuantity : selectedTier.upTo;
|
|
873
889
|
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
}
|
|
877
|
-
} else if (tiersMode === Stigg.TiersMode.VolumePerUnit) {
|
|
878
|
-
if (selectedQuantity && selectedQuantity < unitQuantity) {
|
|
890
|
+
if (!isNil(effectiveQuantity)) {
|
|
891
|
+
if (effectiveQuantity < unitQuantity) {
|
|
879
892
|
return PriceTierComparison.Lower;
|
|
880
893
|
}
|
|
881
894
|
|
|
882
|
-
if (
|
|
895
|
+
if (effectiveQuantity > unitQuantity) {
|
|
883
896
|
return PriceTierComparison.Higher;
|
|
884
897
|
}
|
|
885
898
|
}
|
|
@@ -1179,7 +1192,7 @@ function getPaidPriceText(_ref) {
|
|
|
1179
1192
|
tierUnits = getPriceFeatureUnit(_price);
|
|
1180
1193
|
}
|
|
1181
1194
|
|
|
1182
|
-
priceNumber += calculateTierPrice(_price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]);
|
|
1195
|
+
priceNumber += calculateTierPrice(_price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, (perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]) || 1);
|
|
1183
1196
|
}
|
|
1184
1197
|
}
|
|
1185
1198
|
|
|
@@ -1541,13 +1554,12 @@ var TiersSelectLayout = /*#__PURE__*/_styled(Typography, {
|
|
|
1541
1554
|
})( {
|
|
1542
1555
|
name: "1m2htit",
|
|
1543
1556
|
styles: "min-height:46px",
|
|
1544
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1557
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNNkMiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBnZXRUaWVyQnlRdWFudGl0eSwgaGFzVGllcldpdGhVbml0UHJpY2UgfSBmcm9tICcuLi91dGlscy9wcmljZVRpZXJVdGlscyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBWb2x1bWVQZXJVbml0SW5wdXQgfSBmcm9tICcuL1ZvbHVtZVBlclVuaXRJbnB1dCc7XHJcbmltcG9ydCB7IFZvbHVtZUJ1bGtTZWxlY3QgfSBmcm9tICcuL1ZvbHVtZUJ1bGtTZWxlY3QnO1xyXG5jb25zdCBUaWVyc1NlbGVjdExheW91dCA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIG1pbi1oZWlnaHQ6IDQ2cHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVGllcnNTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgdGllcnMsIGhhbmRsZVRpZXJDaGFuZ2UgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKHF1YW50aXR5KSA9PiB7XHJcbiAgICAgICAgaWYgKCF0aWVycylcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIGhhbmRsZVRpZXJDaGFuZ2UoZ2V0VGllckJ5UXVhbnRpdHkodGllcnMsIHF1YW50aXR5KSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJzU2VsZWN0TGF5b3V0LCB7IGFzOiBcImRpdlwiLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1zZWxlY3RcIiB9LCBoYXNUaWVyV2l0aFVuaXRQcmljZSh0aWVycykgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWb2x1bWVQZXJVbml0SW5wdXQsIE9iamVjdC5hc3NpZ24oeyBoYW5kbGVDaGFuZ2U6IGhhbmRsZUNoYW5nZSB9LCBwcm9wcykpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFZvbHVtZUJ1bGtTZWxlY3QsIE9iamVjdC5hc3NpZ24oeyBoYW5kbGVDaGFuZ2U6IGhhbmRsZUNoYW5nZSB9LCBwcm9wcykpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRpZXJzU2VsZWN0Q29udGFpbmVyLmpzLm1hcCJdfQ== */",
|
|
1545
1558
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
1546
1559
|
});
|
|
1547
1560
|
|
|
1548
1561
|
function TiersSelectContainer(props) {
|
|
1549
1562
|
var tiers = props.tiers,
|
|
1550
|
-
tiersMode = props.tiersMode,
|
|
1551
1563
|
handleTierChange = props.handleTierChange;
|
|
1552
1564
|
|
|
1553
1565
|
var handleChange = function handleChange(quantity) {
|
|
@@ -1555,27 +1567,14 @@ function TiersSelectContainer(props) {
|
|
|
1555
1567
|
handleTierChange(getTierByQuantity(tiers, quantity));
|
|
1556
1568
|
};
|
|
1557
1569
|
|
|
1558
|
-
var getContent = function getContent() {
|
|
1559
|
-
switch (tiersMode) {
|
|
1560
|
-
case Stigg.TiersMode.VolumePerUnit:
|
|
1561
|
-
return React__default.createElement(VolumePerUnitInput, Object.assign({
|
|
1562
|
-
handleChange: handleChange
|
|
1563
|
-
}, props));
|
|
1564
|
-
|
|
1565
|
-
case Stigg.TiersMode.Volume:
|
|
1566
|
-
return React__default.createElement(VolumeBulkSelect, Object.assign({
|
|
1567
|
-
handleChange: handleChange
|
|
1568
|
-
}, props));
|
|
1569
|
-
|
|
1570
|
-
default:
|
|
1571
|
-
return React__default.createElement("div", null);
|
|
1572
|
-
}
|
|
1573
|
-
};
|
|
1574
|
-
|
|
1575
1570
|
return React__default.createElement(TiersSelectLayout, {
|
|
1576
1571
|
as: "div",
|
|
1577
1572
|
className: "stigg-price-tier-select"
|
|
1578
|
-
},
|
|
1573
|
+
}, hasTierWithUnitPrice(tiers) ? React__default.createElement(VolumePerUnitInput, Object.assign({
|
|
1574
|
+
handleChange: handleChange
|
|
1575
|
+
}, props)) : React__default.createElement(VolumeBulkSelect, Object.assign({
|
|
1576
|
+
handleChange: handleChange
|
|
1577
|
+
}, props)));
|
|
1579
1578
|
}
|
|
1580
1579
|
|
|
1581
1580
|
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)."; }
|
|
@@ -2093,7 +2092,7 @@ function getPlanBillingPeriodAmount(plan, billingPeriod) {
|
|
|
2093
2092
|
});
|
|
2094
2093
|
|
|
2095
2094
|
if (tieredPrice) {
|
|
2096
|
-
return tieredPrice.tiers[0]
|
|
2095
|
+
return calculateTierPriceVolume(tieredPrice.tiers[0], 1);
|
|
2097
2096
|
}
|
|
2098
2097
|
}
|
|
2099
2098
|
|
|
@@ -4258,13 +4257,19 @@ function SectionTitle(_ref) {
|
|
|
4258
4257
|
}, title);
|
|
4259
4258
|
}
|
|
4260
4259
|
|
|
4260
|
+
(function (CustomerPortalIntentionType) {
|
|
4261
|
+
CustomerPortalIntentionType["MANAGE_SUBSCRIPTION"] = "MANAGE_SUBSCRIPTION";
|
|
4262
|
+
CustomerPortalIntentionType["UPGRADE_PLAN"] = "UPGRADE_PLAN";
|
|
4263
|
+
CustomerPortalIntentionType["UPGRADE_TRIAL_PLAN"] = "UPGRADE_TRIAL_PLAN";
|
|
4264
|
+
})(exports.CustomerPortalIntentionType || (exports.CustomerPortalIntentionType = {}));
|
|
4265
|
+
|
|
4261
4266
|
var StyledEditIcon = /*#__PURE__*/_styled(SvgEditIcon, {
|
|
4262
4267
|
target: "e1fjw26b0",
|
|
4263
4268
|
label: "StyledEditIcon"
|
|
4264
4269
|
})("path{stroke:", function (_ref) {
|
|
4265
4270
|
var theme = _ref.theme;
|
|
4266
4271
|
return theme.stigg.palette.primary;
|
|
4267
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
4272
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUXdDIiwiZmlsZSI6IlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFN0eWxlZEJ1dHRvbiB9IGZyb20gJy4uL2NvbW1vbi9TdHlsZWRCdXR0b24nO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgRWRpdEljb24gZnJvbSAnLi4vLi4vLi4vYXNzZXRzL2VkaXQtaWNvbi5zdmcnO1xyXG5pbXBvcnQgeyBTZWN0aW9uSGVhZGVyIH0gZnJvbSAnLi4vY29tbW9uL1NlY3Rpb25IZWFkZXInO1xyXG5pbXBvcnQgeyBTZWN0aW9uVGl0bGUgfSBmcm9tICcuLi9jb21tb24vU2VjdGlvblRpdGxlJztcclxuaW1wb3J0IHsgQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlIH0gZnJvbSAnLi4vdHlwZXMnO1xyXG5jb25zdCBTdHlsZWRFZGl0SWNvbiA9IHN0eWxlZChFZGl0SWNvbikgYFxuICBwYXRoIHtcbiAgICBzdHJva2U6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5wcmltYXJ5fTtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlcih7IG9uTWFuYWdlU3Vic2NyaXB0aW9uLCBoaWRlTWFuYWdlQnV0dG9uLCB0ZXh0T3ZlcnJpZGVzLCB9KSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VjdGlvbkhlYWRlciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY3VzdG9tZXItcG9ydGFsLW92ZXJ2aWV3LWhlYWRlclwiLCBcIiRkaXNhYmxlTWFyZ2luXCI6IHRydWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNlY3Rpb25UaXRsZSwgeyB0aXRsZTogXCJTdWJzY3JpcHRpb25cIiwgY2xhc3NOYW1lOiBcInN0aWdnLW92ZXJ2aWV3LXRpdGxlXCIgfSksXHJcbiAgICAgICAgIWhpZGVNYW5hZ2VCdXR0b24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQnV0dG9uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1tYW5hZ2Utc3Vic2NyaXB0aW9uLWJ1dHRvblwiLCB2YXJpYW50OiBcIm91dGxpbmVkXCIsIG9uQ2xpY2s6ICgpID0+IG9uTWFuYWdlU3Vic2NyaXB0aW9uKHsgaW50ZW50aW9uVHlwZTogQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlLk1BTkFHRV9TVUJTQ1JJUFRJT04gfSkgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRFZGl0SWNvbiwgeyBjbGFzc05hbWU6IFwic3RpZ2ctbWFuYWdlLXN1YnNjcmlwdGlvbi1idXR0b24taW1hZ2VcIiB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1tYW5hZ2Utc3Vic2NyaXB0aW9uLWJ1dHRvbi10ZXh0XCIsIGNvbG9yOiBcInByaW1hcnkubWFpblwiLCBzdHlsZTogeyBtYXJnaW5MZWZ0OiAnOHB4JyB9LCB2YXJpYW50OiBcImJvZHkxXCIgfSwgdGV4dE92ZXJyaWRlcz8ubWFuYWdlU3Vic2NyaXB0aW9uKSkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9U3Vic2NyaXB0aW9uc092ZXJ2aWV3SGVhZGVyLmpzLm1hcCJdfQ== */"));
|
|
4268
4273
|
|
|
4269
4274
|
function SubscriptionsOverviewHeader(_ref2) {
|
|
4270
4275
|
var onManageSubscription = _ref2.onManageSubscription,
|
|
@@ -4279,7 +4284,11 @@ function SubscriptionsOverviewHeader(_ref2) {
|
|
|
4279
4284
|
}), !hideManageButton && React__default.createElement(StyledButton$1, {
|
|
4280
4285
|
className: "stigg-manage-subscription-button",
|
|
4281
4286
|
variant: "outlined",
|
|
4282
|
-
onClick:
|
|
4287
|
+
onClick: function onClick() {
|
|
4288
|
+
return onManageSubscription({
|
|
4289
|
+
intentionType: exports.CustomerPortalIntentionType.MANAGE_SUBSCRIPTION
|
|
4290
|
+
});
|
|
4291
|
+
}
|
|
4283
4292
|
}, React__default.createElement(StyledEditIcon, {
|
|
4284
4293
|
className: "stigg-manage-subscription-button-image"
|
|
4285
4294
|
}), React__default.createElement(Typography, {
|
|
@@ -5634,7 +5643,7 @@ var OnTrialBadge = /*#__PURE__*/_styled("div", {
|
|
|
5634
5643
|
})("width:100%;display:flex;align-items:center;gap:4px;background-color:", function (_ref) {
|
|
5635
5644
|
var theme = _ref.theme;
|
|
5636
5645
|
return theme.stigg.palette.warning;
|
|
5637
|
-
}, ";border-radius:10px;padding:8px 16px;margin-top:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5646
|
+
}, ";border-radius:10px;padding:8px 16px;margin-top:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFnQyIsImZpbGUiOiJUcmlhbFBhbmVsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uU3RhdHVzIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgTGluayBmcm9tICdAbXVpL21hdGVyaWFsL0xpbmsnO1xyXG5pbXBvcnQgU2FuZENsb2NrSWNvbiBmcm9tICcuLi8uLi8uLi8uLi9hc3NldHMvc2FuZC1jbG9jay5zdmcnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBMb25nVGV4dCB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9Mb25nVGV4dCc7XHJcbmltcG9ydCB7IEN1c3RvbWVyUG9ydGFsSW50ZW50aW9uVHlwZSB9IGZyb20gJy4uLy4uL3R5cGVzJztcclxuY29uc3QgT25UcmlhbEJhZGdlID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6IDRweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLndhcm5pbmd9O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBwYWRkaW5nOiA4cHggMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQoTGluaykgYFxuICB0ZXh0LWRlY29yYXRpb24tY29sb3I6IHdoaXRlO1xuICBjb2xvcjogd2hpdGU7XG4gIGN1cnNvcjogcG9pbnRlcjtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBUcmlhbFBhbmVsKHsgc3Vic2NyaXB0aW9uLCBpbmNsdWRlUGxhbk5hbWUsIG9uTWFuYWdlU3Vic2NyaXB0aW9uLCB9KSB7XHJcbiAgICBpZiAoc3Vic2NyaXB0aW9uPy5zdGF0dXMgIT09IFN1YnNjcmlwdGlvblN0YXR1cy5JblRyaWFsKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoT25UcmlhbEJhZGdlLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtYmFkZ2VcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2FuZENsb2NrSWNvbiwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLWltYWdlXCIgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7IHN0eWxlOiB7IGZsZXg6IDEsIG1hcmdpblJpZ2h0OiA0IH0gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMb25nVGV4dCwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtYmFkZ2UtdGV4dFwiLCBjb2xvcjogXCJ3aGl0ZVwiIH0sXHJcbiAgICAgICAgICAgICAgICBgJHtzdWJzY3JpcHRpb24udHJpYWxSZW1haW5pbmdEYXlzfSBkYXlzIHJlbWFpbmluZyBpbiB0cmlhbGAsXHJcbiAgICAgICAgICAgICAgICBpbmNsdWRlUGxhbk5hbWUgJiYgYCBvZiB0aGUgJHtzdWJzY3JpcHRpb24ucGxhbk5hbWV9IHBsYW5gKSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMaW5rLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtdXBncmFkZS1idXR0b25cIiwgb25DbGljazogKCkgPT4gb25NYW5hZ2VTdWJzY3JpcHRpb24oeyBpbnRlbnRpb25UeXBlOiBDdXN0b21lclBvcnRhbEludGVudGlvblR5cGUuVVBHUkFERV9UUklBTF9QTEFOIH0pIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJ3aGl0ZVwiIH0sIFwiVXBncmFkZSBwbGFuXCIpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyaWFsUGFuZWwuanMubWFwIl19 */"));
|
|
5638
5647
|
|
|
5639
5648
|
var StyledLink = /*#__PURE__*/_styled(Link, {
|
|
5640
5649
|
target: "el5iwyw0",
|
|
@@ -5642,7 +5651,7 @@ var StyledLink = /*#__PURE__*/_styled(Link, {
|
|
|
5642
5651
|
})( {
|
|
5643
5652
|
name: "69ka7t",
|
|
5644
5653
|
styles: "text-decoration-color:white;color:white;cursor:pointer",
|
|
5645
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5654
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCZ0MiLCJmaWxlIjoiVHJpYWxQYW5lbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvblN0YXR1cyB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IExpbmsgZnJvbSAnQG11aS9tYXRlcmlhbC9MaW5rJztcclxuaW1wb3J0IFNhbmRDbG9ja0ljb24gZnJvbSAnLi4vLi4vLi4vLi4vYXNzZXRzL3NhbmQtY2xvY2suc3ZnJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgTG9uZ1RleHQgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vTG9uZ1RleHQnO1xyXG5pbXBvcnQgeyBDdXN0b21lclBvcnRhbEludGVudGlvblR5cGUgfSBmcm9tICcuLi8uLi90eXBlcyc7XHJcbmNvbnN0IE9uVHJpYWxCYWRnZSA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiA0cHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS53YXJuaW5nfTtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgcGFkZGluZzogOHB4IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5jb25zdCBTdHlsZWRMaW5rID0gc3R5bGVkKExpbmspIGBcbiAgdGV4dC1kZWNvcmF0aW9uLWNvbG9yOiB3aGl0ZTtcbiAgY29sb3I6IHdoaXRlO1xuICBjdXJzb3I6IHBvaW50ZXI7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVHJpYWxQYW5lbCh7IHN1YnNjcmlwdGlvbiwgaW5jbHVkZVBsYW5OYW1lLCBvbk1hbmFnZVN1YnNjcmlwdGlvbiwgfSkge1xyXG4gICAgaWYgKHN1YnNjcmlwdGlvbj8uc3RhdHVzICE9PSBTdWJzY3JpcHRpb25TdGF0dXMuSW5UcmlhbCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KE9uVHJpYWxCYWRnZSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlXCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNhbmRDbG9ja0ljb24sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC1iYWRnZS1pbWFnZVwiIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyBzdHlsZTogeyBmbGV4OiAxLCBtYXJnaW5SaWdodDogNCB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9uZ1RleHQsIHsgdmFyaWFudDogXCJib2R5MVwiLCBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLXRleHRcIiwgY29sb3I6IFwid2hpdGVcIiB9LFxyXG4gICAgICAgICAgICAgICAgYCR7c3Vic2NyaXB0aW9uLnRyaWFsUmVtYWluaW5nRGF5c30gZGF5cyByZW1haW5pbmcgaW4gdHJpYWxgLFxyXG4gICAgICAgICAgICAgICAgaW5jbHVkZVBsYW5OYW1lICYmIGAgb2YgdGhlICR7c3Vic2NyaXB0aW9uLnBsYW5OYW1lfSBwbGFuYCkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGluaywgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLXVwZ3JhZGUtYnV0dG9uXCIsIG9uQ2xpY2s6ICgpID0+IG9uTWFuYWdlU3Vic2NyaXB0aW9uKHsgaW50ZW50aW9uVHlwZTogQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlLlVQR1JBREVfVFJJQUxfUExBTiB9KSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY29sb3I6IFwid2hpdGVcIiB9LCBcIlVwZ3JhZGUgcGxhblwiKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UcmlhbFBhbmVsLmpzLm1hcCJdfQ== */",
|
|
5646
5655
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$f
|
|
5647
5656
|
});
|
|
5648
5657
|
|
|
@@ -5670,7 +5679,11 @@ function TrialPanel(_ref2) {
|
|
|
5670
5679
|
color: "white"
|
|
5671
5680
|
}, subscription.trialRemainingDays + " days remaining in trial", includePlanName && " of the " + subscription.planName + " plan")), React__default.createElement(StyledLink, {
|
|
5672
5681
|
className: "stigg-subscription-trial-upgrade-button",
|
|
5673
|
-
onClick:
|
|
5682
|
+
onClick: function onClick() {
|
|
5683
|
+
return onManageSubscription({
|
|
5684
|
+
intentionType: exports.CustomerPortalIntentionType.UPGRADE_TRIAL_PLAN
|
|
5685
|
+
});
|
|
5686
|
+
}
|
|
5674
5687
|
}, React__default.createElement(Typography, {
|
|
5675
5688
|
color: "white"
|
|
5676
5689
|
}, "Upgrade plan")));
|
|
@@ -5825,7 +5838,11 @@ function EntitlementCtaButton(_ref) {
|
|
|
5825
5838
|
if (canUpgradeSubscription) {
|
|
5826
5839
|
return onManageSubscription ? React__default.createElement(StyledButton$2, {
|
|
5827
5840
|
variant: "text",
|
|
5828
|
-
onClick:
|
|
5841
|
+
onClick: function onClick() {
|
|
5842
|
+
return onManageSubscription({
|
|
5843
|
+
intentionType: exports.CustomerPortalIntentionType.UPGRADE_PLAN
|
|
5844
|
+
});
|
|
5845
|
+
}
|
|
5829
5846
|
}, React__default.createElement(Typography, {
|
|
5830
5847
|
color: "primary.main"
|
|
5831
5848
|
}, "Upgrade")) : null;
|
|
@@ -6563,10 +6580,16 @@ function CustomerPortalContainer(_ref) {
|
|
|
6563
6580
|
|
|
6564
6581
|
var customerPortalSectionRef = React.useRef(null);
|
|
6565
6582
|
|
|
6566
|
-
var onManageClick = function onManageClick() {
|
|
6583
|
+
var onManageClick = function onManageClick(_ref2) {
|
|
6584
|
+
var intentionType = _ref2.intentionType;
|
|
6585
|
+
|
|
6567
6586
|
if (onManageSubscription) {
|
|
6568
|
-
|
|
6569
|
-
|
|
6587
|
+
var _customerPortal$subsc;
|
|
6588
|
+
|
|
6589
|
+
void onManageSubscription({
|
|
6590
|
+
intentionType: intentionType,
|
|
6591
|
+
customerSubscriptions: (_customerPortal$subsc = customerPortal == null ? void 0 : customerPortal.subscriptions) != null ? _customerPortal$subsc : []
|
|
6592
|
+
});
|
|
6570
6593
|
} else {
|
|
6571
6594
|
var _customerPortalSectio;
|
|
6572
6595
|
|
|
@@ -7000,7 +7023,7 @@ function getBillableFeatures(preconfiguredBillableFeatures, planPrices, activeSu
|
|
|
7000
7023
|
var preconfiguredQuantity = ((_preconfBillableFeatu = preconfBillableFeaturesByFeatureId[featureId]) == null ? void 0 : _preconfBillableFeatu.quantity) || ((_quantityByFeatureId$ = quantityByFeatureId[featureId]) == null ? void 0 : _quantityByFeatureId$.quantity);
|
|
7001
7024
|
quantity = getValidPriceQuantity(price, preconfiguredQuantity || 1);
|
|
7002
7025
|
|
|
7003
|
-
if (price.isTieredPrice && price.
|
|
7026
|
+
if (price.isTieredPrice && !hasTierWithUnitPrice(price.tiers)) {
|
|
7004
7027
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
7005
7028
|
quantity = tier.upTo;
|
|
7006
7029
|
}
|
|
@@ -12197,7 +12220,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", {
|
|
|
12197
12220
|
})( {
|
|
12198
12221
|
name: "rdmn2i",
|
|
12199
12222
|
styles: "&+&{margin-top:8px;}",
|
|
12200
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12223
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAW4C","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { calculateTierPriceVolume, getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (quantity) {\r\n        amount /= quantity;\r\n    }\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = calculateTierPriceVolume(tier, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
|
|
12201
12224
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12202
12225
|
});
|
|
12203
12226
|
var LineItemRow = /*#__PURE__*/_styled("div", {
|
|
@@ -12206,7 +12229,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", {
|
|
|
12206
12229
|
})( {
|
|
12207
12230
|
name: "bcffy2",
|
|
12208
12231
|
styles: "display:flex;align-items:center;justify-content:space-between",
|
|
12209
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12232
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAgBsC","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { calculateTierPriceVolume, getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (quantity) {\r\n        amount /= quantity;\r\n    }\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = calculateTierPriceVolume(tier, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
|
|
12210
12233
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12211
12234
|
});
|
|
12212
12235
|
var getPriceString = function getPriceString(_ref) {
|
|
@@ -12216,6 +12239,10 @@ var getPriceString = function getPriceString(_ref) {
|
|
|
12216
12239
|
var billingPeriod = price.billingPeriod;
|
|
12217
12240
|
var billingPeriodString = null;
|
|
12218
12241
|
|
|
12242
|
+
if (quantity) {
|
|
12243
|
+
amount /= quantity;
|
|
12244
|
+
}
|
|
12245
|
+
|
|
12219
12246
|
if (billingPeriod === Stigg.BillingPeriod.Annually) {
|
|
12220
12247
|
amount /= 12;
|
|
12221
12248
|
billingPeriodString = '12 months';
|
|
@@ -12256,7 +12283,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12256
12283
|
|
|
12257
12284
|
if (price.isTieredPrice) {
|
|
12258
12285
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
12259
|
-
amount = tier
|
|
12286
|
+
amount = calculateTierPriceVolume(tier, quantity);
|
|
12260
12287
|
} else {
|
|
12261
12288
|
amount = price.amount;
|
|
12262
12289
|
}
|
|
@@ -12291,7 +12318,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12291
12318
|
wordBreak: 'break-word'
|
|
12292
12319
|
}
|
|
12293
12320
|
}, currencyPriceFormatter({
|
|
12294
|
-
amount:
|
|
12321
|
+
amount: amount,
|
|
12295
12322
|
currency: price.currency,
|
|
12296
12323
|
minimumFractionDigits: 2
|
|
12297
12324
|
}), isPayAsYouGo && ' / unit'))));
|