@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
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, TiersMode, BillingPeriod, 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, useCallback, useMemo, useRef, useEffect, useContext } from 'react';
|
|
4
4
|
import _styled from '@emotion/styled/base';
|
|
@@ -6,7 +6,7 @@ import classNames from 'classnames';
|
|
|
6
6
|
import Grid from '@mui/material/Grid';
|
|
7
7
|
import { Text, FontWeight } from 'styled-typography';
|
|
8
8
|
import { useTheme, css, Global, ThemeProvider as ThemeProvider$1 } from '@emotion/react';
|
|
9
|
-
import { compact, map, isFunction, countBy, uniq, merge as merge$1, keyBy, padStart, range, partition as partition$1 } from 'lodash-es';
|
|
9
|
+
import { compact, map, sum, isFunction, countBy, uniq, merge as merge$1, keyBy, padStart, range, partition as partition$1 } from 'lodash-es';
|
|
10
10
|
import ClipLoader from 'react-spinners/ClipLoader';
|
|
11
11
|
import Color from 'color';
|
|
12
12
|
import merge from 'lodash-es/merge';
|
|
@@ -775,7 +775,47 @@ function calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingP
|
|
|
775
775
|
|
|
776
776
|
return amount;
|
|
777
777
|
}
|
|
778
|
-
|
|
778
|
+
|
|
779
|
+
function calculateTierPriceGraduated(tiers, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
780
|
+
var remainingQuantity = unitQuantity;
|
|
781
|
+
var prevUpTo = 0;
|
|
782
|
+
var currentTierIndex = 0;
|
|
783
|
+
var breakdown = [];
|
|
784
|
+
|
|
785
|
+
while (remainingQuantity > 0 && currentTierIndex < tiers.length) {
|
|
786
|
+
var tier = tiers[currentTierIndex];
|
|
787
|
+
var upTo = tier.upTo;
|
|
788
|
+
|
|
789
|
+
if (isNil(upTo)) {
|
|
790
|
+
breakdown.push({
|
|
791
|
+
unitQuantity: remainingQuantity,
|
|
792
|
+
amount: calculateTierPriceVolume(tier, remainingQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount)
|
|
793
|
+
});
|
|
794
|
+
remainingQuantity = 0;
|
|
795
|
+
} else {
|
|
796
|
+
var unitsInTier = upTo - prevUpTo;
|
|
797
|
+
var consumed = Math.min(remainingQuantity, unitsInTier);
|
|
798
|
+
breakdown.push({
|
|
799
|
+
unitQuantity: consumed,
|
|
800
|
+
amount: calculateTierPriceVolume(tier, consumed, selectedBillingPeriod, shouldShowMonthlyPriceAmount)
|
|
801
|
+
});
|
|
802
|
+
remainingQuantity -= consumed;
|
|
803
|
+
prevUpTo = upTo;
|
|
804
|
+
}
|
|
805
|
+
|
|
806
|
+
currentTierIndex += 1;
|
|
807
|
+
}
|
|
808
|
+
|
|
809
|
+
var total = sum(breakdown.map(function (_ref) {
|
|
810
|
+
var amount = _ref.amount;
|
|
811
|
+
return amount;
|
|
812
|
+
}));
|
|
813
|
+
return {
|
|
814
|
+
breakdown: breakdown,
|
|
815
|
+
total: total
|
|
816
|
+
};
|
|
817
|
+
}
|
|
818
|
+
function calculateTierPrice(price, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
|
|
779
819
|
if (!price.tiers) {
|
|
780
820
|
return 0;
|
|
781
821
|
}
|
|
@@ -787,14 +827,19 @@ function calculateTierPrice(price, selectedBillingPeriod, shouldShowMonthlyPrice
|
|
|
787
827
|
return calculateTierPriceVolume(currentTier, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
788
828
|
}
|
|
789
829
|
|
|
830
|
+
case TiersMode.Graduated:
|
|
831
|
+
{
|
|
832
|
+
return calculateTierPriceGraduated(price.tiers, unitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount).total;
|
|
833
|
+
}
|
|
834
|
+
|
|
790
835
|
default:
|
|
791
836
|
return 0;
|
|
792
837
|
}
|
|
793
838
|
}
|
|
794
839
|
function hasTierWithUnitPrice(tiers) {
|
|
795
|
-
return tiers == null ? void 0 : tiers.some(function (
|
|
796
|
-
var unitPrice =
|
|
797
|
-
upTo =
|
|
840
|
+
return tiers == null ? void 0 : tiers.some(function (_ref2) {
|
|
841
|
+
var unitPrice = _ref2.unitPrice,
|
|
842
|
+
upTo = _ref2.upTo;
|
|
798
843
|
return unitPrice && !isNil(upTo);
|
|
799
844
|
});
|
|
800
845
|
}
|
|
@@ -1184,7 +1229,7 @@ function getPaidPriceText(_ref) {
|
|
|
1184
1229
|
var quantity = (perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]) || 1;
|
|
1185
1230
|
tiers = _price.tiers;
|
|
1186
1231
|
tierUnits = getPriceFeatureUnit(_price);
|
|
1187
|
-
priceNumber += calculateTierPrice(_price, selectedBillingPeriod, shouldShowMonthlyPriceAmount
|
|
1232
|
+
priceNumber += calculateTierPrice(_price, quantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
|
|
1188
1233
|
}
|
|
1189
1234
|
}
|
|
1190
1235
|
|
|
@@ -2125,7 +2170,7 @@ function getPlanBillingPeriodAmount(plan, billingPeriod) {
|
|
|
2125
2170
|
});
|
|
2126
2171
|
|
|
2127
2172
|
if (tieredPrice) {
|
|
2128
|
-
return
|
|
2173
|
+
return calculateTierPrice(tieredPrice, 1);
|
|
2129
2174
|
}
|
|
2130
2175
|
}
|
|
2131
2176
|
|
|
@@ -12486,7 +12531,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
|
|
|
12486
12531
|
} : {
|
|
12487
12532
|
name: "rdmn2i",
|
|
12488
12533
|
styles: "&+&{margin-top:8px;}",
|
|
12489
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12534
|
+
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"]} */",
|
|
12490
12535
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12491
12536
|
});
|
|
12492
12537
|
var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -12500,7 +12545,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
|
|
|
12500
12545
|
} : {
|
|
12501
12546
|
name: "bcffy2",
|
|
12502
12547
|
styles: "display:flex;align-items:center;justify-content:space-between",
|
|
12503
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
12548
|
+
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"]} */",
|
|
12504
12549
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12505
12550
|
});
|
|
12506
12551
|
var getPriceString = function getPriceString(_ref) {
|
|
@@ -12553,13 +12598,11 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12553
12598
|
var amount;
|
|
12554
12599
|
|
|
12555
12600
|
if (price.isTieredPrice) {
|
|
12556
|
-
|
|
12557
|
-
amount = calculateTierPriceVolume(tier, quantity);
|
|
12601
|
+
amount = calculateTierPrice(price, quantity);
|
|
12558
12602
|
} else {
|
|
12559
|
-
amount = price.amount;
|
|
12603
|
+
amount = price.amount * quantity;
|
|
12560
12604
|
}
|
|
12561
12605
|
|
|
12562
|
-
var totalLineAmount = price.isTieredPrice ? amount : amount * quantity;
|
|
12563
12606
|
return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
|
|
12564
12607
|
style: {
|
|
12565
12608
|
alignItems: 'flex-start'
|
|
@@ -12573,7 +12616,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12573
12616
|
variant: "body1",
|
|
12574
12617
|
color: "secondary"
|
|
12575
12618
|
}, getPriceString({
|
|
12576
|
-
amount:
|
|
12619
|
+
amount: amount,
|
|
12577
12620
|
price: price,
|
|
12578
12621
|
quantity: quantity
|
|
12579
12622
|
}))), React__default.createElement(Grid, {
|
|
@@ -12590,7 +12633,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12590
12633
|
wordBreak: 'break-word'
|
|
12591
12634
|
}
|
|
12592
12635
|
}, currencyPriceFormatter({
|
|
12593
|
-
amount:
|
|
12636
|
+
amount: amount,
|
|
12594
12637
|
currency: price.currency,
|
|
12595
12638
|
minimumFractionDigits: 2
|
|
12596
12639
|
}), isPayAsYouGo && ' / unit'))));
|