@stigg/react-sdk 4.15.0 → 5.1.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/paywall/paywallTextOverrides.d.ts +6 -1
- package/dist/components/utils/priceTierUtils.d.ts +3 -1
- package/dist/react-sdk.cjs.development.js +49 -46
- 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 +51 -48
- 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/utils/calculateDiscountRate.ts +2 -1
- package/src/components/utils/getPaidPriceText.ts +1 -1
- package/src/components/utils/priceTierUtils.ts +41 -21
- package/src/stories/mocks/checkout/mockCheckoutState.ts +4 -4
|
@@ -65,7 +65,12 @@ export declare function getResolvedPaywallLocalize(localizeOverride?: DeepPartia
|
|
|
65
65
|
__typename?: "Money" | undefined;
|
|
66
66
|
amount?: number | undefined;
|
|
67
67
|
currency?: import("@stigg/js-client-sdk").Currency | undefined;
|
|
68
|
-
} | undefined;
|
|
68
|
+
} | null | undefined;
|
|
69
|
+
flatPrice?: {
|
|
70
|
+
__typename?: "Money" | undefined;
|
|
71
|
+
amount?: number | undefined;
|
|
72
|
+
currency?: import("@stigg/js-client-sdk").Currency | undefined;
|
|
73
|
+
} | null | undefined;
|
|
69
74
|
} | undefined)[] | null | undefined;
|
|
70
75
|
tierUnits?: string | undefined;
|
|
71
76
|
} | {} | undefined;
|
|
@@ -3,8 +3,10 @@ import { PaywallPlan } from '../paywall';
|
|
|
3
3
|
import { SelectDefaultTierIndexFn } from '../paywall/types';
|
|
4
4
|
export declare function getPriceFeatureUnit(price: Price): string;
|
|
5
5
|
export declare function getTierByQuantity(tiers: PriceTierFragment[], quantity: number): PriceTierFragment | undefined;
|
|
6
|
-
export declare function
|
|
6
|
+
export declare function calculateTierPriceVolume(currentTier: PriceTierFragment, perUnitQuantity: number, selectedBillingPeriod?: BillingPeriod, shouldShowMonthlyPriceAmount?: boolean): number;
|
|
7
|
+
export declare function calculateTierPrice(price: Price, currentTier: PriceTierFragment, selectedBillingPeriod: BillingPeriod, shouldShowMonthlyPriceAmount: boolean, perUnitQuantity: number): number;
|
|
7
8
|
export declare function getSelectedTierQuantityBeFeature(plan: PaywallPlan, billingPeriod: BillingPeriod, currentSubscription: Subscription | null): Record<string, number>;
|
|
9
|
+
export declare function hasTierWithUnitPrice(tiers: PriceTierFragment[] | null | undefined): boolean | undefined;
|
|
8
10
|
export declare function getSelectedTier(plan: PaywallPlan, billingPeriod: BillingPeriod, currentSubscription: Subscription | null, selectedTierByFeature: Record<string, PriceTierFragment>, selectDefaultTierIndex?: SelectDefaultTierIndexFn): Record<string, PriceTierFragment>;
|
|
9
11
|
export declare enum PriceTierComparison {
|
|
10
12
|
Lower = -1,
|
|
@@ -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
|
|
|
@@ -7024,7 +7023,7 @@ function getBillableFeatures(preconfiguredBillableFeatures, planPrices, activeSu
|
|
|
7024
7023
|
var preconfiguredQuantity = ((_preconfBillableFeatu = preconfBillableFeaturesByFeatureId[featureId]) == null ? void 0 : _preconfBillableFeatu.quantity) || ((_quantityByFeatureId$ = quantityByFeatureId[featureId]) == null ? void 0 : _quantityByFeatureId$.quantity);
|
|
7025
7024
|
quantity = getValidPriceQuantity(price, preconfiguredQuantity || 1);
|
|
7026
7025
|
|
|
7027
|
-
if (price.isTieredPrice && price.
|
|
7026
|
+
if (price.isTieredPrice && !hasTierWithUnitPrice(price.tiers)) {
|
|
7028
7027
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
7029
7028
|
quantity = tier.upTo;
|
|
7030
7029
|
}
|
|
@@ -12221,7 +12220,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", {
|
|
|
12221
12220
|
})( {
|
|
12222
12221
|
name: "rdmn2i",
|
|
12223
12222
|
styles: "&+&{margin-top:8px;}",
|
|
12224
|
-
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"]} */",
|
|
12225
12224
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12226
12225
|
});
|
|
12227
12226
|
var LineItemRow = /*#__PURE__*/_styled("div", {
|
|
@@ -12230,7 +12229,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", {
|
|
|
12230
12229
|
})( {
|
|
12231
12230
|
name: "bcffy2",
|
|
12232
12231
|
styles: "display:flex;align-items:center;justify-content:space-between",
|
|
12233
|
-
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"]} */",
|
|
12234
12233
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12235
12234
|
});
|
|
12236
12235
|
var getPriceString = function getPriceString(_ref) {
|
|
@@ -12240,6 +12239,10 @@ var getPriceString = function getPriceString(_ref) {
|
|
|
12240
12239
|
var billingPeriod = price.billingPeriod;
|
|
12241
12240
|
var billingPeriodString = null;
|
|
12242
12241
|
|
|
12242
|
+
if (quantity) {
|
|
12243
|
+
amount /= quantity;
|
|
12244
|
+
}
|
|
12245
|
+
|
|
12243
12246
|
if (billingPeriod === Stigg.BillingPeriod.Annually) {
|
|
12244
12247
|
amount /= 12;
|
|
12245
12248
|
billingPeriodString = '12 months';
|
|
@@ -12280,7 +12283,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12280
12283
|
|
|
12281
12284
|
if (price.isTieredPrice) {
|
|
12282
12285
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
12283
|
-
amount = tier
|
|
12286
|
+
amount = calculateTierPriceVolume(tier, quantity);
|
|
12284
12287
|
} else {
|
|
12285
12288
|
amount = price.amount;
|
|
12286
12289
|
}
|
|
@@ -12315,7 +12318,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12315
12318
|
wordBreak: 'break-word'
|
|
12316
12319
|
}
|
|
12317
12320
|
}, currencyPriceFormatter({
|
|
12318
|
-
amount:
|
|
12321
|
+
amount: amount,
|
|
12319
12322
|
currency: price.currency,
|
|
12320
12323
|
minimumFractionDigits: 2
|
|
12321
12324
|
}), isPayAsYouGo && ' / unit'))));
|