@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
package/dist/react-sdk.esm.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import Stigg__default, { EntitlementResetPeriod, WidgetType, SubscriptionScheduleType, BillingModel,
|
|
1
|
+
import Stigg__default, { EntitlementResetPeriod, WidgetType, SubscriptionScheduleType, BillingModel, BillingPeriod, TiersMode, PricingType, Currency, SubscriptionStatus, FontWeight as FontWeight$1, Alignment, MeterType, DiscountType, DiscountDurationType, BillingVendorIdentifier, PaymentCollection } from '@stigg/js-client-sdk';
|
|
2
2
|
export * from '@stigg/js-client-sdk';
|
|
3
3
|
import React__default, { createElement, forwardRef, useState, useEffect, useCallback, useMemo, useRef, useContext } from 'react';
|
|
4
4
|
import _styled from '@emotion/styled/base';
|
|
@@ -42,7 +42,7 @@ import cloneDeep from 'lodash-es/cloneDeep';
|
|
|
42
42
|
import remove from 'lodash-es/remove';
|
|
43
43
|
import keyBy$1 from 'lodash-es/keyBy';
|
|
44
44
|
import compact$1 from 'lodash-es/compact';
|
|
45
|
-
import {
|
|
45
|
+
import { BillingPeriod as BillingPeriod$1 } from '@stigg/api-client-js/src/generated/sdk';
|
|
46
46
|
import { AddressElement, PaymentElement, useStripe, useElements, Elements } from '@stripe/react-stripe-js';
|
|
47
47
|
import StepIcon from '@mui/material/StepIcon';
|
|
48
48
|
import partition from 'lodash-es/partition';
|
|
@@ -757,18 +757,30 @@ function getTierByQuantity(tiers, quantity) {
|
|
|
757
757
|
|
|
758
758
|
return ascendingTiers[ascendingTiers.length - 1];
|
|
759
759
|
}
|
|
760
|
-
function calculateTierPrice(price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantity) {
|
|
761
|
-
var unitPrice = selectedBillingPeriod === BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? currentTier.unitPrice.amount / 12 : currentTier.unitPrice.amount;
|
|
762
760
|
|
|
761
|
+
function getAmount(amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
762
|
+
return selectedBillingPeriod === BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? amount / 12 : amount;
|
|
763
|
+
}
|
|
764
|
+
|
|
765
|
+
function calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
766
|
+
var amount = 0;
|
|
767
|
+
|
|
768
|
+
if (currentTier.unitPrice) {
|
|
769
|
+
var unitPrice = getAmount(currentTier.unitPrice.amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
770
|
+
amount += unitPrice * perUnitQuantity;
|
|
771
|
+
}
|
|
772
|
+
|
|
773
|
+
if (currentTier.flatPrice) {
|
|
774
|
+
amount += getAmount(currentTier.flatPrice.amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
775
|
+
}
|
|
776
|
+
|
|
777
|
+
return amount;
|
|
778
|
+
}
|
|
779
|
+
function calculateTierPrice(price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantity) {
|
|
763
780
|
switch (price.tiersMode) {
|
|
764
781
|
case TiersMode.Volume:
|
|
765
782
|
{
|
|
766
|
-
return
|
|
767
|
-
}
|
|
768
|
-
|
|
769
|
-
case TiersMode.VolumePerUnit:
|
|
770
|
-
{
|
|
771
|
-
return unitPrice * (perUnitQuantity || 1);
|
|
783
|
+
return calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
772
784
|
}
|
|
773
785
|
|
|
774
786
|
default:
|
|
@@ -802,6 +814,13 @@ function getSelectedTierQuantityBeFeature(plan, billingPeriod, currentSubscripti
|
|
|
802
814
|
|
|
803
815
|
return result;
|
|
804
816
|
}
|
|
817
|
+
function hasTierWithUnitPrice(tiers) {
|
|
818
|
+
return tiers == null ? void 0 : tiers.some(function (_ref) {
|
|
819
|
+
var unitPrice = _ref.unitPrice,
|
|
820
|
+
upTo = _ref.upTo;
|
|
821
|
+
return unitPrice && !isNil(upTo);
|
|
822
|
+
});
|
|
823
|
+
}
|
|
805
824
|
function getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature, selectDefaultTierIndex) {
|
|
806
825
|
var planTierPrices = plan.pricePoints.filter(function (price) {
|
|
807
826
|
return price.billingPeriod === billingPeriod && price.isTieredPrice;
|
|
@@ -864,7 +883,7 @@ function compareSelectedTierToCurrentTier(selectedTierByFeature, perUnitQuantity
|
|
|
864
883
|
var _currentTierPrice$fea = currentTierPrice.feature,
|
|
865
884
|
featureId = _currentTierPrice$fea.featureId,
|
|
866
885
|
unitQuantity = _currentTierPrice$fea.unitQuantity;
|
|
867
|
-
var
|
|
886
|
+
var tiers = currentTierPrice.tiers;
|
|
868
887
|
|
|
869
888
|
if (!unitQuantity) {
|
|
870
889
|
return PriceTierComparison.Equal;
|
|
@@ -877,20 +896,14 @@ function compareSelectedTierToCurrentTier(selectedTierByFeature, perUnitQuantity
|
|
|
877
896
|
return PriceTierComparison.Equal;
|
|
878
897
|
}
|
|
879
898
|
|
|
880
|
-
|
|
881
|
-
if (selectedTier.upTo && selectedTier.upTo < unitQuantity) {
|
|
882
|
-
return PriceTierComparison.Lower;
|
|
883
|
-
}
|
|
899
|
+
var effectiveQuantity = hasTierWithUnitPrice(tiers) ? selectedQuantity : selectedTier.upTo;
|
|
884
900
|
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
}
|
|
888
|
-
} else if (tiersMode === TiersMode.VolumePerUnit) {
|
|
889
|
-
if (selectedQuantity && selectedQuantity < unitQuantity) {
|
|
901
|
+
if (!isNil(effectiveQuantity)) {
|
|
902
|
+
if (effectiveQuantity < unitQuantity) {
|
|
890
903
|
return PriceTierComparison.Lower;
|
|
891
904
|
}
|
|
892
905
|
|
|
893
|
-
if (
|
|
906
|
+
if (effectiveQuantity > unitQuantity) {
|
|
894
907
|
return PriceTierComparison.Higher;
|
|
895
908
|
}
|
|
896
909
|
}
|
|
@@ -1216,7 +1229,7 @@ function getPaidPriceText(_ref) {
|
|
|
1216
1229
|
tierUnits = getPriceFeatureUnit(_price);
|
|
1217
1230
|
}
|
|
1218
1231
|
|
|
1219
|
-
priceNumber += calculateTierPrice(_price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]);
|
|
1232
|
+
priceNumber += calculateTierPrice(_price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, (perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]) || 1);
|
|
1220
1233
|
}
|
|
1221
1234
|
}
|
|
1222
1235
|
|
|
@@ -1614,13 +1627,12 @@ var TiersSelectLayout = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV ==
|
|
|
1614
1627
|
} : {
|
|
1615
1628
|
name: "1m2htit",
|
|
1616
1629
|
styles: "min-height:46px",
|
|
1617
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1630
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNNkMiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBnZXRUaWVyQnlRdWFudGl0eSwgaGFzVGllcldpdGhVbml0UHJpY2UgfSBmcm9tICcuLi91dGlscy9wcmljZVRpZXJVdGlscyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBWb2x1bWVQZXJVbml0SW5wdXQgfSBmcm9tICcuL1ZvbHVtZVBlclVuaXRJbnB1dCc7XHJcbmltcG9ydCB7IFZvbHVtZUJ1bGtTZWxlY3QgfSBmcm9tICcuL1ZvbHVtZUJ1bGtTZWxlY3QnO1xyXG5jb25zdCBUaWVyc1NlbGVjdExheW91dCA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIG1pbi1oZWlnaHQ6IDQ2cHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVGllcnNTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgdGllcnMsIGhhbmRsZVRpZXJDaGFuZ2UgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKHF1YW50aXR5KSA9PiB7XHJcbiAgICAgICAgaWYgKCF0aWVycylcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIGhhbmRsZVRpZXJDaGFuZ2UoZ2V0VGllckJ5UXVhbnRpdHkodGllcnMsIHF1YW50aXR5KSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJzU2VsZWN0TGF5b3V0LCB7IGFzOiBcImRpdlwiLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1zZWxlY3RcIiB9LCBoYXNUaWVyV2l0aFVuaXRQcmljZSh0aWVycykgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWb2x1bWVQZXJVbml0SW5wdXQsIE9iamVjdC5hc3NpZ24oeyBoYW5kbGVDaGFuZ2U6IGhhbmRsZUNoYW5nZSB9LCBwcm9wcykpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFZvbHVtZUJ1bGtTZWxlY3QsIE9iamVjdC5hc3NpZ24oeyBoYW5kbGVDaGFuZ2U6IGhhbmRsZUNoYW5nZSB9LCBwcm9wcykpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRpZXJzU2VsZWN0Q29udGFpbmVyLmpzLm1hcCJdfQ== */",
|
|
1618
1631
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
1619
1632
|
});
|
|
1620
1633
|
|
|
1621
1634
|
function TiersSelectContainer(props) {
|
|
1622
1635
|
var tiers = props.tiers,
|
|
1623
|
-
tiersMode = props.tiersMode,
|
|
1624
1636
|
handleTierChange = props.handleTierChange;
|
|
1625
1637
|
|
|
1626
1638
|
var handleChange = function handleChange(quantity) {
|
|
@@ -1628,27 +1640,14 @@ function TiersSelectContainer(props) {
|
|
|
1628
1640
|
handleTierChange(getTierByQuantity(tiers, quantity));
|
|
1629
1641
|
};
|
|
1630
1642
|
|
|
1631
|
-
var getContent = function getContent() {
|
|
1632
|
-
switch (tiersMode) {
|
|
1633
|
-
case TiersMode.VolumePerUnit:
|
|
1634
|
-
return React__default.createElement(VolumePerUnitInput, Object.assign({
|
|
1635
|
-
handleChange: handleChange
|
|
1636
|
-
}, props));
|
|
1637
|
-
|
|
1638
|
-
case TiersMode.Volume:
|
|
1639
|
-
return React__default.createElement(VolumeBulkSelect, Object.assign({
|
|
1640
|
-
handleChange: handleChange
|
|
1641
|
-
}, props));
|
|
1642
|
-
|
|
1643
|
-
default:
|
|
1644
|
-
return React__default.createElement("div", null);
|
|
1645
|
-
}
|
|
1646
|
-
};
|
|
1647
|
-
|
|
1648
1643
|
return React__default.createElement(TiersSelectLayout, {
|
|
1649
1644
|
as: "div",
|
|
1650
1645
|
className: "stigg-price-tier-select"
|
|
1651
|
-
},
|
|
1646
|
+
}, hasTierWithUnitPrice(tiers) ? React__default.createElement(VolumePerUnitInput, Object.assign({
|
|
1647
|
+
handleChange: handleChange
|
|
1648
|
+
}, props)) : React__default.createElement(VolumeBulkSelect, Object.assign({
|
|
1649
|
+
handleChange: handleChange
|
|
1650
|
+
}, props)));
|
|
1652
1651
|
}
|
|
1653
1652
|
|
|
1654
1653
|
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)."; }
|
|
@@ -2214,7 +2213,7 @@ function getPlanBillingPeriodAmount(plan, billingPeriod) {
|
|
|
2214
2213
|
});
|
|
2215
2214
|
|
|
2216
2215
|
if (tieredPrice) {
|
|
2217
|
-
return tieredPrice.tiers[0]
|
|
2216
|
+
return calculateTierPriceVolume(tieredPrice.tiers[0], 1);
|
|
2218
2217
|
}
|
|
2219
2218
|
}
|
|
2220
2219
|
|
|
@@ -4427,6 +4426,14 @@ function SectionTitle(_ref) {
|
|
|
4427
4426
|
}, title);
|
|
4428
4427
|
}
|
|
4429
4428
|
|
|
4429
|
+
var CustomerPortalIntentionType;
|
|
4430
|
+
|
|
4431
|
+
(function (CustomerPortalIntentionType) {
|
|
4432
|
+
CustomerPortalIntentionType["MANAGE_SUBSCRIPTION"] = "MANAGE_SUBSCRIPTION";
|
|
4433
|
+
CustomerPortalIntentionType["UPGRADE_PLAN"] = "UPGRADE_PLAN";
|
|
4434
|
+
CustomerPortalIntentionType["UPGRADE_TRIAL_PLAN"] = "UPGRADE_TRIAL_PLAN";
|
|
4435
|
+
})(CustomerPortalIntentionType || (CustomerPortalIntentionType = {}));
|
|
4436
|
+
|
|
4430
4437
|
var StyledEditIcon = /*#__PURE__*/_styled(SvgEditIcon, process.env.NODE_ENV === "production" ? {
|
|
4431
4438
|
target: "e1fjw26b0"
|
|
4432
4439
|
} : {
|
|
@@ -4435,7 +4442,7 @@ var StyledEditIcon = /*#__PURE__*/_styled(SvgEditIcon, process.env.NODE_ENV ===
|
|
|
4435
4442
|
})("path{stroke:", function (_ref) {
|
|
4436
4443
|
var theme = _ref.theme;
|
|
4437
4444
|
return theme.stigg.palette.primary;
|
|
4438
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
4445
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUXdDIiwiZmlsZSI6IlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFN0eWxlZEJ1dHRvbiB9IGZyb20gJy4uL2NvbW1vbi9TdHlsZWRCdXR0b24nO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgRWRpdEljb24gZnJvbSAnLi4vLi4vLi4vYXNzZXRzL2VkaXQtaWNvbi5zdmcnO1xyXG5pbXBvcnQgeyBTZWN0aW9uSGVhZGVyIH0gZnJvbSAnLi4vY29tbW9uL1NlY3Rpb25IZWFkZXInO1xyXG5pbXBvcnQgeyBTZWN0aW9uVGl0bGUgfSBmcm9tICcuLi9jb21tb24vU2VjdGlvblRpdGxlJztcclxuaW1wb3J0IHsgQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlIH0gZnJvbSAnLi4vdHlwZXMnO1xyXG5jb25zdCBTdHlsZWRFZGl0SWNvbiA9IHN0eWxlZChFZGl0SWNvbikgYFxuICBwYXRoIHtcbiAgICBzdHJva2U6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5wcmltYXJ5fTtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlcih7IG9uTWFuYWdlU3Vic2NyaXB0aW9uLCBoaWRlTWFuYWdlQnV0dG9uLCB0ZXh0T3ZlcnJpZGVzLCB9KSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VjdGlvbkhlYWRlciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY3VzdG9tZXItcG9ydGFsLW92ZXJ2aWV3LWhlYWRlclwiLCBcIiRkaXNhYmxlTWFyZ2luXCI6IHRydWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNlY3Rpb25UaXRsZSwgeyB0aXRsZTogXCJTdWJzY3JpcHRpb25cIiwgY2xhc3NOYW1lOiBcInN0aWdnLW92ZXJ2aWV3LXRpdGxlXCIgfSksXHJcbiAgICAgICAgIWhpZGVNYW5hZ2VCdXR0b24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQnV0dG9uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1tYW5hZ2Utc3Vic2NyaXB0aW9uLWJ1dHRvblwiLCB2YXJpYW50OiBcIm91dGxpbmVkXCIsIG9uQ2xpY2s6ICgpID0+IG9uTWFuYWdlU3Vic2NyaXB0aW9uKHsgaW50ZW50aW9uVHlwZTogQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlLk1BTkFHRV9TVUJTQ1JJUFRJT04gfSkgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRFZGl0SWNvbiwgeyBjbGFzc05hbWU6IFwic3RpZ2ctbWFuYWdlLXN1YnNjcmlwdGlvbi1idXR0b24taW1hZ2VcIiB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1tYW5hZ2Utc3Vic2NyaXB0aW9uLWJ1dHRvbi10ZXh0XCIsIGNvbG9yOiBcInByaW1hcnkubWFpblwiLCBzdHlsZTogeyBtYXJnaW5MZWZ0OiAnOHB4JyB9LCB2YXJpYW50OiBcImJvZHkxXCIgfSwgdGV4dE92ZXJyaWRlcz8ubWFuYWdlU3Vic2NyaXB0aW9uKSkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9U3Vic2NyaXB0aW9uc092ZXJ2aWV3SGVhZGVyLmpzLm1hcCJdfQ== */"));
|
|
4439
4446
|
|
|
4440
4447
|
function SubscriptionsOverviewHeader(_ref2) {
|
|
4441
4448
|
var onManageSubscription = _ref2.onManageSubscription,
|
|
@@ -4450,7 +4457,11 @@ function SubscriptionsOverviewHeader(_ref2) {
|
|
|
4450
4457
|
}), !hideManageButton && React__default.createElement(StyledButton$1, {
|
|
4451
4458
|
className: "stigg-manage-subscription-button",
|
|
4452
4459
|
variant: "outlined",
|
|
4453
|
-
onClick:
|
|
4460
|
+
onClick: function onClick() {
|
|
4461
|
+
return onManageSubscription({
|
|
4462
|
+
intentionType: CustomerPortalIntentionType.MANAGE_SUBSCRIPTION
|
|
4463
|
+
});
|
|
4464
|
+
}
|
|
4454
4465
|
}, React__default.createElement(StyledEditIcon, {
|
|
4455
4466
|
className: "stigg-manage-subscription-button-image"
|
|
4456
4467
|
}), React__default.createElement(Typography, {
|
|
@@ -5873,7 +5884,7 @@ var OnTrialBadge = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "product
|
|
|
5873
5884
|
})("width:100%;display:flex;align-items:center;gap:4px;background-color:", function (_ref) {
|
|
5874
5885
|
var theme = _ref.theme;
|
|
5875
5886
|
return theme.stigg.palette.warning;
|
|
5876
|
-
}, ";border-radius:10px;padding:8px 16px;margin-top:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5887
|
+
}, ";border-radius:10px;padding:8px 16px;margin-top:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFnQyIsImZpbGUiOiJUcmlhbFBhbmVsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uU3RhdHVzIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgTGluayBmcm9tICdAbXVpL21hdGVyaWFsL0xpbmsnO1xyXG5pbXBvcnQgU2FuZENsb2NrSWNvbiBmcm9tICcuLi8uLi8uLi8uLi9hc3NldHMvc2FuZC1jbG9jay5zdmcnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBMb25nVGV4dCB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9Mb25nVGV4dCc7XHJcbmltcG9ydCB7IEN1c3RvbWVyUG9ydGFsSW50ZW50aW9uVHlwZSB9IGZyb20gJy4uLy4uL3R5cGVzJztcclxuY29uc3QgT25UcmlhbEJhZGdlID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6IDRweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLndhcm5pbmd9O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBwYWRkaW5nOiA4cHggMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQoTGluaykgYFxuICB0ZXh0LWRlY29yYXRpb24tY29sb3I6IHdoaXRlO1xuICBjb2xvcjogd2hpdGU7XG4gIGN1cnNvcjogcG9pbnRlcjtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBUcmlhbFBhbmVsKHsgc3Vic2NyaXB0aW9uLCBpbmNsdWRlUGxhbk5hbWUsIG9uTWFuYWdlU3Vic2NyaXB0aW9uLCB9KSB7XHJcbiAgICBpZiAoc3Vic2NyaXB0aW9uPy5zdGF0dXMgIT09IFN1YnNjcmlwdGlvblN0YXR1cy5JblRyaWFsKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoT25UcmlhbEJhZGdlLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtYmFkZ2VcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2FuZENsb2NrSWNvbiwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLWltYWdlXCIgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7IHN0eWxlOiB7IGZsZXg6IDEsIG1hcmdpblJpZ2h0OiA0IH0gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMb25nVGV4dCwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtYmFkZ2UtdGV4dFwiLCBjb2xvcjogXCJ3aGl0ZVwiIH0sXHJcbiAgICAgICAgICAgICAgICBgJHtzdWJzY3JpcHRpb24udHJpYWxSZW1haW5pbmdEYXlzfSBkYXlzIHJlbWFpbmluZyBpbiB0cmlhbGAsXHJcbiAgICAgICAgICAgICAgICBpbmNsdWRlUGxhbk5hbWUgJiYgYCBvZiB0aGUgJHtzdWJzY3JpcHRpb24ucGxhbk5hbWV9IHBsYW5gKSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMaW5rLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtdXBncmFkZS1idXR0b25cIiwgb25DbGljazogKCkgPT4gb25NYW5hZ2VTdWJzY3JpcHRpb24oeyBpbnRlbnRpb25UeXBlOiBDdXN0b21lclBvcnRhbEludGVudGlvblR5cGUuVVBHUkFERV9UUklBTF9QTEFOIH0pIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJ3aGl0ZVwiIH0sIFwiVXBncmFkZSBwbGFuXCIpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyaWFsUGFuZWwuanMubWFwIl19 */"));
|
|
5877
5888
|
|
|
5878
5889
|
var StyledLink = /*#__PURE__*/_styled(Link, process.env.NODE_ENV === "production" ? {
|
|
5879
5890
|
target: "el5iwyw0"
|
|
@@ -5886,7 +5897,7 @@ var StyledLink = /*#__PURE__*/_styled(Link, process.env.NODE_ENV === "production
|
|
|
5886
5897
|
} : {
|
|
5887
5898
|
name: "69ka7t",
|
|
5888
5899
|
styles: "text-decoration-color:white;color:white;cursor:pointer",
|
|
5889
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5900
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCZ0MiLCJmaWxlIjoiVHJpYWxQYW5lbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvblN0YXR1cyB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IExpbmsgZnJvbSAnQG11aS9tYXRlcmlhbC9MaW5rJztcclxuaW1wb3J0IFNhbmRDbG9ja0ljb24gZnJvbSAnLi4vLi4vLi4vLi4vYXNzZXRzL3NhbmQtY2xvY2suc3ZnJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgTG9uZ1RleHQgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vTG9uZ1RleHQnO1xyXG5pbXBvcnQgeyBDdXN0b21lclBvcnRhbEludGVudGlvblR5cGUgfSBmcm9tICcuLi8uLi90eXBlcyc7XHJcbmNvbnN0IE9uVHJpYWxCYWRnZSA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiA0cHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS53YXJuaW5nfTtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgcGFkZGluZzogOHB4IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5jb25zdCBTdHlsZWRMaW5rID0gc3R5bGVkKExpbmspIGBcbiAgdGV4dC1kZWNvcmF0aW9uLWNvbG9yOiB3aGl0ZTtcbiAgY29sb3I6IHdoaXRlO1xuICBjdXJzb3I6IHBvaW50ZXI7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVHJpYWxQYW5lbCh7IHN1YnNjcmlwdGlvbiwgaW5jbHVkZVBsYW5OYW1lLCBvbk1hbmFnZVN1YnNjcmlwdGlvbiwgfSkge1xyXG4gICAgaWYgKHN1YnNjcmlwdGlvbj8uc3RhdHVzICE9PSBTdWJzY3JpcHRpb25TdGF0dXMuSW5UcmlhbCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KE9uVHJpYWxCYWRnZSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlXCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNhbmRDbG9ja0ljb24sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC1iYWRnZS1pbWFnZVwiIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyBzdHlsZTogeyBmbGV4OiAxLCBtYXJnaW5SaWdodDogNCB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9uZ1RleHQsIHsgdmFyaWFudDogXCJib2R5MVwiLCBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLXRleHRcIiwgY29sb3I6IFwid2hpdGVcIiB9LFxyXG4gICAgICAgICAgICAgICAgYCR7c3Vic2NyaXB0aW9uLnRyaWFsUmVtYWluaW5nRGF5c30gZGF5cyByZW1haW5pbmcgaW4gdHJpYWxgLFxyXG4gICAgICAgICAgICAgICAgaW5jbHVkZVBsYW5OYW1lICYmIGAgb2YgdGhlICR7c3Vic2NyaXB0aW9uLnBsYW5OYW1lfSBwbGFuYCkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGluaywgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLXVwZ3JhZGUtYnV0dG9uXCIsIG9uQ2xpY2s6ICgpID0+IG9uTWFuYWdlU3Vic2NyaXB0aW9uKHsgaW50ZW50aW9uVHlwZTogQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlLlVQR1JBREVfVFJJQUxfUExBTiB9KSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY29sb3I6IFwid2hpdGVcIiB9LCBcIlVwZ3JhZGUgcGxhblwiKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UcmlhbFBhbmVsLmpzLm1hcCJdfQ== */",
|
|
5890
5901
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$f
|
|
5891
5902
|
});
|
|
5892
5903
|
|
|
@@ -5914,7 +5925,11 @@ function TrialPanel(_ref2) {
|
|
|
5914
5925
|
color: "white"
|
|
5915
5926
|
}, subscription.trialRemainingDays + " days remaining in trial", includePlanName && " of the " + subscription.planName + " plan")), React__default.createElement(StyledLink, {
|
|
5916
5927
|
className: "stigg-subscription-trial-upgrade-button",
|
|
5917
|
-
onClick:
|
|
5928
|
+
onClick: function onClick() {
|
|
5929
|
+
return onManageSubscription({
|
|
5930
|
+
intentionType: CustomerPortalIntentionType.UPGRADE_TRIAL_PLAN
|
|
5931
|
+
});
|
|
5932
|
+
}
|
|
5918
5933
|
}, React__default.createElement(Typography, {
|
|
5919
5934
|
color: "white"
|
|
5920
5935
|
}, "Upgrade plan")));
|
|
@@ -6076,7 +6091,11 @@ function EntitlementCtaButton(_ref) {
|
|
|
6076
6091
|
if (canUpgradeSubscription) {
|
|
6077
6092
|
return onManageSubscription ? React__default.createElement(StyledButton$2, {
|
|
6078
6093
|
variant: "text",
|
|
6079
|
-
onClick:
|
|
6094
|
+
onClick: function onClick() {
|
|
6095
|
+
return onManageSubscription({
|
|
6096
|
+
intentionType: CustomerPortalIntentionType.UPGRADE_PLAN
|
|
6097
|
+
});
|
|
6098
|
+
}
|
|
6080
6099
|
}, React__default.createElement(Typography, {
|
|
6081
6100
|
color: "primary.main"
|
|
6082
6101
|
}, "Upgrade")) : null;
|
|
@@ -6855,10 +6874,16 @@ function CustomerPortalContainer(_ref) {
|
|
|
6855
6874
|
|
|
6856
6875
|
var customerPortalSectionRef = useRef(null);
|
|
6857
6876
|
|
|
6858
|
-
var onManageClick = function onManageClick() {
|
|
6877
|
+
var onManageClick = function onManageClick(_ref2) {
|
|
6878
|
+
var intentionType = _ref2.intentionType;
|
|
6879
|
+
|
|
6859
6880
|
if (onManageSubscription) {
|
|
6860
|
-
|
|
6861
|
-
|
|
6881
|
+
var _customerPortal$subsc;
|
|
6882
|
+
|
|
6883
|
+
void onManageSubscription({
|
|
6884
|
+
intentionType: intentionType,
|
|
6885
|
+
customerSubscriptions: (_customerPortal$subsc = customerPortal == null ? void 0 : customerPortal.subscriptions) != null ? _customerPortal$subsc : []
|
|
6886
|
+
});
|
|
6862
6887
|
} else {
|
|
6863
6888
|
var _customerPortalSectio;
|
|
6864
6889
|
|
|
@@ -7292,7 +7317,7 @@ function getBillableFeatures(preconfiguredBillableFeatures, planPrices, activeSu
|
|
|
7292
7317
|
var preconfiguredQuantity = ((_preconfBillableFeatu = preconfBillableFeaturesByFeatureId[featureId]) == null ? void 0 : _preconfBillableFeatu.quantity) || ((_quantityByFeatureId$ = quantityByFeatureId[featureId]) == null ? void 0 : _quantityByFeatureId$.quantity);
|
|
7293
7318
|
quantity = getValidPriceQuantity(price, preconfiguredQuantity || 1);
|
|
7294
7319
|
|
|
7295
|
-
if (price.isTieredPrice && price.
|
|
7320
|
+
if (price.isTieredPrice && !hasTierWithUnitPrice(price.tiers)) {
|
|
7296
7321
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
7297
7322
|
quantity = tier.upTo;
|
|
7298
7323
|
}
|
|
@@ -12549,7 +12574,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
|
|
|
12549
12574
|
} : {
|
|
12550
12575
|
name: "rdmn2i",
|
|
12551
12576
|
styles: "&+&{margin-top:8px;}",
|
|
12552
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12577
|
+
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"]} */",
|
|
12553
12578
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12554
12579
|
});
|
|
12555
12580
|
var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -12563,7 +12588,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
|
|
|
12563
12588
|
} : {
|
|
12564
12589
|
name: "bcffy2",
|
|
12565
12590
|
styles: "display:flex;align-items:center;justify-content:space-between",
|
|
12566
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12591
|
+
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"]} */",
|
|
12567
12592
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12568
12593
|
});
|
|
12569
12594
|
var getPriceString = function getPriceString(_ref) {
|
|
@@ -12573,6 +12598,10 @@ var getPriceString = function getPriceString(_ref) {
|
|
|
12573
12598
|
var billingPeriod = price.billingPeriod;
|
|
12574
12599
|
var billingPeriodString = null;
|
|
12575
12600
|
|
|
12601
|
+
if (quantity) {
|
|
12602
|
+
amount /= quantity;
|
|
12603
|
+
}
|
|
12604
|
+
|
|
12576
12605
|
if (billingPeriod === BillingPeriod.Annually) {
|
|
12577
12606
|
amount /= 12;
|
|
12578
12607
|
billingPeriodString = '12 months';
|
|
@@ -12613,7 +12642,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12613
12642
|
|
|
12614
12643
|
if (price.isTieredPrice) {
|
|
12615
12644
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
12616
|
-
amount = tier
|
|
12645
|
+
amount = calculateTierPriceVolume(tier, quantity);
|
|
12617
12646
|
} else {
|
|
12618
12647
|
amount = price.amount;
|
|
12619
12648
|
}
|
|
@@ -12648,7 +12677,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12648
12677
|
wordBreak: 'break-word'
|
|
12649
12678
|
}
|
|
12650
12679
|
}, currencyPriceFormatter({
|
|
12651
|
-
amount:
|
|
12680
|
+
amount: amount,
|
|
12652
12681
|
currency: price.currency,
|
|
12653
12682
|
minimumFractionDigits: 2
|
|
12654
12683
|
}), isPayAsYouGo && ' / unit'))));
|
|
@@ -14581,5 +14610,5 @@ var useWaitForCheckoutCompleted = function useWaitForCheckoutCompleted(_temp) {
|
|
|
14581
14610
|
};
|
|
14582
14611
|
};
|
|
14583
14612
|
|
|
14584
|
-
export { AddonsList, Checkout, CustomerPortal, CustomerPortalProvider, CustomerUsageData, InvoicesSection, PaymentDetailsSection, PaywallContainer$1 as Paywall, Promotions, ProvisionStatus, StiggContext, StiggProvider, SubscribeIntentionType, SubscriptionsOverview, useStiggContext, useWaitForCheckoutCompleted };
|
|
14613
|
+
export { AddonsList, Checkout, CustomerPortal, CustomerPortalIntentionType, CustomerPortalProvider, CustomerUsageData, InvoicesSection, PaymentDetailsSection, PaywallContainer$1 as Paywall, Promotions, ProvisionStatus, StiggContext, StiggProvider, SubscribeIntentionType, SubscriptionsOverview, useStiggContext, useWaitForCheckoutCompleted };
|
|
14585
14614
|
//# sourceMappingURL=react-sdk.esm.js.map
|