@stigg/react-sdk 4.15.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/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
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
|
|
|
@@ -7318,7 +7317,7 @@ function getBillableFeatures(preconfiguredBillableFeatures, planPrices, activeSu
|
|
|
7318
7317
|
var preconfiguredQuantity = ((_preconfBillableFeatu = preconfBillableFeaturesByFeatureId[featureId]) == null ? void 0 : _preconfBillableFeatu.quantity) || ((_quantityByFeatureId$ = quantityByFeatureId[featureId]) == null ? void 0 : _quantityByFeatureId$.quantity);
|
|
7319
7318
|
quantity = getValidPriceQuantity(price, preconfiguredQuantity || 1);
|
|
7320
7319
|
|
|
7321
|
-
if (price.isTieredPrice && price.
|
|
7320
|
+
if (price.isTieredPrice && !hasTierWithUnitPrice(price.tiers)) {
|
|
7322
7321
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
7323
7322
|
quantity = tier.upTo;
|
|
7324
7323
|
}
|
|
@@ -12575,7 +12574,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
|
|
|
12575
12574
|
} : {
|
|
12576
12575
|
name: "rdmn2i",
|
|
12577
12576
|
styles: "&+&{margin-top:8px;}",
|
|
12578
|
-
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"]} */",
|
|
12579
12578
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12580
12579
|
});
|
|
12581
12580
|
var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -12589,7 +12588,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
|
|
|
12589
12588
|
} : {
|
|
12590
12589
|
name: "bcffy2",
|
|
12591
12590
|
styles: "display:flex;align-items:center;justify-content:space-between",
|
|
12592
|
-
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"]} */",
|
|
12593
12592
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12594
12593
|
});
|
|
12595
12594
|
var getPriceString = function getPriceString(_ref) {
|
|
@@ -12599,6 +12598,10 @@ var getPriceString = function getPriceString(_ref) {
|
|
|
12599
12598
|
var billingPeriod = price.billingPeriod;
|
|
12600
12599
|
var billingPeriodString = null;
|
|
12601
12600
|
|
|
12601
|
+
if (quantity) {
|
|
12602
|
+
amount /= quantity;
|
|
12603
|
+
}
|
|
12604
|
+
|
|
12602
12605
|
if (billingPeriod === BillingPeriod.Annually) {
|
|
12603
12606
|
amount /= 12;
|
|
12604
12607
|
billingPeriodString = '12 months';
|
|
@@ -12639,7 +12642,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12639
12642
|
|
|
12640
12643
|
if (price.isTieredPrice) {
|
|
12641
12644
|
var tier = getTierByQuantity(price.tiers, quantity);
|
|
12642
|
-
amount = tier
|
|
12645
|
+
amount = calculateTierPriceVolume(tier, quantity);
|
|
12643
12646
|
} else {
|
|
12644
12647
|
amount = price.amount;
|
|
12645
12648
|
}
|
|
@@ -12674,7 +12677,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
|
12674
12677
|
wordBreak: 'break-word'
|
|
12675
12678
|
}
|
|
12676
12679
|
}, currencyPriceFormatter({
|
|
12677
|
-
amount:
|
|
12680
|
+
amount: amount,
|
|
12678
12681
|
currency: price.currency,
|
|
12679
12682
|
minimumFractionDigits: 2
|
|
12680
12683
|
}), isPayAsYouGo && ' / unit'))));
|