@stigg/react-sdk 5.3.0 → 5.4.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/utils/fixtures/price.fixtures.d.ts +7 -0
- package/dist/components/utils/priceTierUtils.d.ts +8 -2
- package/dist/components/utils/priceTierUtils.spec.d.ts +1 -0
- package/dist/react-sdk.cjs.development.js +57 -14
- 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 +59 -16
- package/dist/react-sdk.esm.js.map +1 -1
- package/package.json +2 -2
- package/src/components/checkout/summary/components/LineItems.tsx +5 -8
- package/src/components/utils/calculateDiscountRate.ts +2 -2
- package/src/components/utils/fixtures/price.fixtures.ts +42 -0
- package/src/components/utils/getPaidPriceText.ts +1 -1
- package/src/components/utils/priceTierUtils.spec.ts +84 -0
- package/src/components/utils/priceTierUtils.ts +53 -4
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Currency, Price, TiersMode } from '@stigg/js-client-sdk';
|
|
2
|
+
export declare const money: (amount: number, currency: Currency) => {
|
|
3
|
+
amount: number;
|
|
4
|
+
currency: Currency;
|
|
5
|
+
};
|
|
6
|
+
export declare const priceTiersFlat: (tiersMode: TiersMode, currency: Currency) => Pick<Price, 'tiers' | 'tiersMode'>;
|
|
7
|
+
export declare const priceTiersUnit: (tiersMode: TiersMode, currency: Currency) => Pick<Price, 'tiers' | 'tiersMode'>;
|
|
@@ -3,8 +3,14 @@ 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;
|
|
6
|
-
export declare function
|
|
7
|
-
|
|
6
|
+
export declare function calculateTierPriceGraduated(tiers: PriceTierFragment[], unitQuantity: number, selectedBillingPeriod?: BillingPeriod, shouldShowMonthlyPriceAmount?: boolean): {
|
|
7
|
+
total: number;
|
|
8
|
+
breakdown: Array<{
|
|
9
|
+
unitQuantity: number;
|
|
10
|
+
amount: number;
|
|
11
|
+
}>;
|
|
12
|
+
};
|
|
13
|
+
export declare function calculateTierPrice(price: Pick<Price, 'tiers' | 'tiersMode'>, unitQuantity: number, selectedBillingPeriod?: BillingPeriod, shouldShowMonthlyPriceAmount?: boolean): number;
|
|
8
14
|
export declare function hasTierWithUnitPrice(tiers: PriceTierFragment[] | null | undefined): boolean | undefined;
|
|
9
15
|
export declare function getTiersPerUnitQuantities(plan: PaywallPlan, billingPeriod: BillingPeriod, currentSubscription: Subscription | null, selectDefaultTierIndex?: SelectDefaultTierIndexFn): Record<string, number>;
|
|
10
16
|
export declare enum PriceTierComparison {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -764,7 +764,47 @@ function calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingP
|
|
|
764
764
|
|
|
765
765
|
return amount;
|
|
766
766
|
}
|
|
767
|
-
|
|
767
|
+
|
|
768
|
+
function calculateTierPriceGraduated(tiers, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
769
|
+
var remainingQuantity = unitQuantity;
|
|
770
|
+
var prevUpTo = 0;
|
|
771
|
+
var currentTierIndex = 0;
|
|
772
|
+
var breakdown = [];
|
|
773
|
+
|
|
774
|
+
while (remainingQuantity > 0 && currentTierIndex < tiers.length) {
|
|
775
|
+
var tier = tiers[currentTierIndex];
|
|
776
|
+
var upTo = tier.upTo;
|
|
777
|
+
|
|
778
|
+
if (isNil(upTo)) {
|
|
779
|
+
breakdown.push({
|
|
780
|
+
unitQuantity: remainingQuantity,
|
|
781
|
+
amount: calculateTierPriceVolume(tier, remainingQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount)
|
|
782
|
+
});
|
|
783
|
+
remainingQuantity = 0;
|
|
784
|
+
} else {
|
|
785
|
+
var unitsInTier = upTo - prevUpTo;
|
|
786
|
+
var consumed = Math.min(remainingQuantity, unitsInTier);
|
|
787
|
+
breakdown.push({
|
|
788
|
+
unitQuantity: consumed,
|
|
789
|
+
amount: calculateTierPriceVolume(tier, consumed, selectedBillingPeriod, shouldShowMonthlyPriceAmount)
|
|
790
|
+
});
|
|
791
|
+
remainingQuantity -= consumed;
|
|
792
|
+
prevUpTo = upTo;
|
|
793
|
+
}
|
|
794
|
+
|
|
795
|
+
currentTierIndex += 1;
|
|
796
|
+
}
|
|
797
|
+
|
|
798
|
+
var total = lodash.sum(breakdown.map(function (_ref) {
|
|
799
|
+
var amount = _ref.amount;
|
|
800
|
+
return amount;
|
|
801
|
+
}));
|
|
802
|
+
return {
|
|
803
|
+
breakdown: breakdown,
|
|
804
|
+
total: total
|
|
805
|
+
};
|
|
806
|
+
}
|
|
807
|
+
function calculateTierPrice(price, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
768
808
|
if (!price.tiers) {
|
|
769
809
|
return 0;
|
|
770
810
|
}
|
|
@@ -776,14 +816,19 @@ function calculateTierPrice(price, selectedBillingPeriod, shouldShowMonthlyPrice
|
|
|
776
816
|
return calculateTierPriceVolume(currentTier, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
777
817
|
}
|
|
778
818
|
|
|
819
|
+
case Stigg.TiersMode.Graduated:
|
|
820
|
+
{
|
|
821
|
+
return calculateTierPriceGraduated(price.tiers, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount).total;
|
|
822
|
+
}
|
|
823
|
+
|
|
779
824
|
default:
|
|
780
825
|
return 0;
|
|
781
826
|
}
|
|
782
827
|
}
|
|
783
828
|
function hasTierWithUnitPrice(tiers) {
|
|
784
|
-
return tiers == null ? void 0 : tiers.some(function (
|
|
785
|
-
var unitPrice =
|
|
786
|
-
upTo =
|
|
829
|
+
return tiers == null ? void 0 : tiers.some(function (_ref2) {
|
|
830
|
+
var unitPrice = _ref2.unitPrice,
|
|
831
|
+
upTo = _ref2.upTo;
|
|
787
832
|
return unitPrice && !isNil(upTo);
|
|
788
833
|
});
|
|
789
834
|
}
|
|
@@ -1147,7 +1192,7 @@ function getPaidPriceText(_ref) {
|
|
|
1147
1192
|
var quantity = (perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]) || 1;
|
|
1148
1193
|
tiers = _price.tiers;
|
|
1149
1194
|
tierUnits = getPriceFeatureUnit(_price);
|
|
1150
|
-
priceNumber += calculateTierPrice(_price, selectedBillingPeriod, shouldShowMonthlyPriceAmount
|
|
1195
|
+
priceNumber += calculateTierPrice(_price, quantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
1151
1196
|
}
|
|
1152
1197
|
}
|
|
1153
1198
|
|
|
@@ -2004,7 +2049,7 @@ function getPlanBillingPeriodAmount(plan, billingPeriod) {
|
|
|
2004
2049
|
});
|
|
2005
2050
|
|
|
2006
2051
|
if (tieredPrice) {
|
|
2007
|
-
return
|
|
2052
|
+
return calculateTierPrice(tieredPrice, 1);
|
|
2008
2053
|
}
|
|
2009
2054
|
}
|
|
2010
2055
|
|
|
@@ -12132,7 +12177,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", {
|
|
|
12132
12177
|
})( {
|
|
12133
12178
|
name: "rdmn2i",
|
|
12134
12179
|
styles: "&+&{margin-top:8px;}",
|
|
12135
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12180
|
+
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 { calculateTierPrice } 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        amount = calculateTierPrice(price, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount * quantity;\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({\r\n                        amount,\r\n                        currency: price.currency,\r\n                        minimumFractionDigits: 2,\r\n                    }),\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"]} */",
|
|
12136
12181
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12137
12182
|
});
|
|
12138
12183
|
var LineItemRow = /*#__PURE__*/_styled("div", {
|
|
@@ -12141,7 +12186,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", {
|
|
|
12141
12186
|
})( {
|
|
12142
12187
|
name: "bcffy2",
|
|
12143
12188
|
styles: "display:flex;align-items:center;justify-content:space-between",
|
|
12144
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12189
|
+
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 { calculateTierPrice } 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        amount = calculateTierPrice(price, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount * quantity;\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({\r\n                        amount,\r\n                        currency: price.currency,\r\n                        minimumFractionDigits: 2,\r\n                    }),\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"]} */",
|
|
12145
12190
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12146
12191
|
});
|
|
12147
12192
|
var getPriceString = function getPriceString(_ref) {
|
|
@@ -12194,13 +12239,11 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12194
12239
|
var amount;
|
|
12195
12240
|
|
|
12196
12241
|
if (price.isTieredPrice) {
|
|
12197
|
-
|
|
12198
|
-
amount = calculateTierPriceVolume(tier, quantity);
|
|
12242
|
+
amount = calculateTierPrice(price, quantity);
|
|
12199
12243
|
} else {
|
|
12200
|
-
amount = price.amount;
|
|
12244
|
+
amount = price.amount * quantity;
|
|
12201
12245
|
}
|
|
12202
12246
|
|
|
12203
|
-
var totalLineAmount = price.isTieredPrice ? amount : amount * quantity;
|
|
12204
12247
|
return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
|
|
12205
12248
|
style: {
|
|
12206
12249
|
alignItems: 'flex-start'
|
|
@@ -12214,7 +12257,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12214
12257
|
variant: "body1",
|
|
12215
12258
|
color: "secondary"
|
|
12216
12259
|
}, getPriceString({
|
|
12217
|
-
amount:
|
|
12260
|
+
amount: amount,
|
|
12218
12261
|
price: price,
|
|
12219
12262
|
quantity: quantity
|
|
12220
12263
|
}))), React__default.createElement(Grid, {
|
|
@@ -12231,7 +12274,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12231
12274
|
wordBreak: 'break-word'
|
|
12232
12275
|
}
|
|
12233
12276
|
}, currencyPriceFormatter({
|
|
12234
|
-
amount:
|
|
12277
|
+
amount: amount,
|
|
12235
12278
|
currency: price.currency,
|
|
12236
12279
|
minimumFractionDigits: 2
|
|
12237
12280
|
}), isPayAsYouGo && ' / unit'))));
|