@stigg/react-sdk 6.9.1 → 6.11.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/checkout/CheckoutProvider.d.ts +1 -0
- package/dist/components/checkout/hooks/useCheckoutModel.d.ts +2 -0
- package/dist/components/checkout/steps/payment/PaymentMethods.d.ts +2 -2
- package/dist/components/checkout/steps/payment/PaymentStep.d.ts +1 -1
- package/dist/components/checkout/steps/payment/zuora/ZuoraPaymentForm.d.ts +3 -0
- package/dist/components/checkout/steps/payment/zuora/index.d.ts +3 -0
- package/dist/components/checkout/steps/payment/zuora/useZuoraIntegration.d.ts +5 -0
- package/dist/components/checkout/steps/payment/zuora/useZuoraSubmit.d.ts +11 -0
- package/dist/components/checkout/steps/payment/zuora/zuora.utils.d.ts +34 -0
- package/dist/react-sdk.cjs.development.js +583 -48
- 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 +583 -48
- package/dist/react-sdk.esm.js.map +1 -1
- package/package.json +2 -2
- package/src/components/checkout/CheckoutContainer.tsx +19 -3
- package/src/components/checkout/CheckoutProvider.tsx +2 -0
- package/src/components/checkout/hooks/useCheckoutModel.ts +14 -3
- package/src/components/checkout/steps/payment/PaymentMethods.tsx +15 -2
- package/src/components/checkout/steps/payment/PaymentStep.tsx +8 -1
- package/src/components/checkout/steps/payment/zuora/ZuoraPaymentForm.tsx +128 -0
- package/src/components/checkout/steps/payment/zuora/index.ts +11 -0
- package/src/components/checkout/steps/payment/zuora/useZuoraIntegration.ts +56 -0
- package/src/components/checkout/steps/payment/zuora/useZuoraSubmit.ts +125 -0
- package/src/components/checkout/steps/payment/zuora/zuora.utils.ts +72 -0
- package/src/components/checkout/summary/CheckoutSummary.tsx +71 -44
|
@@ -4223,7 +4223,7 @@ function mapPaywallData(paywall, showOnlyEligiblePlans, currentSubscriptionOverr
|
|
|
4223
4223
|
};
|
|
4224
4224
|
}
|
|
4225
4225
|
|
|
4226
|
-
var version = "6.
|
|
4226
|
+
var version = "6.11.0";
|
|
4227
4227
|
var name = "@stigg/react-sdk";
|
|
4228
4228
|
|
|
4229
4229
|
var StiggContext = /*#__PURE__*/React__default.createContext(null);
|
|
@@ -7190,12 +7190,14 @@ function useCheckoutState() {
|
|
|
7190
7190
|
_useCheckoutContext$ = _useCheckoutContext[0],
|
|
7191
7191
|
checkout = _useCheckoutContext$.checkout,
|
|
7192
7192
|
widgetState = _useCheckoutContext$.widgetState,
|
|
7193
|
-
checkoutLocalization = _useCheckoutContext$.checkoutLocalization
|
|
7193
|
+
checkoutLocalization = _useCheckoutContext$.checkoutLocalization,
|
|
7194
|
+
checkoutSuccess = _useCheckoutContext$.checkoutSuccess;
|
|
7194
7195
|
|
|
7195
7196
|
return {
|
|
7196
7197
|
checkoutState: checkout,
|
|
7197
7198
|
widgetState: widgetState,
|
|
7198
|
-
checkoutLocalization: checkoutLocalization
|
|
7199
|
+
checkoutLocalization: checkoutLocalization,
|
|
7200
|
+
checkoutSuccess: checkoutSuccess
|
|
7199
7201
|
};
|
|
7200
7202
|
}
|
|
7201
7203
|
|
|
@@ -7221,18 +7223,32 @@ function useSetIsValid() {
|
|
|
7221
7223
|
};
|
|
7222
7224
|
}
|
|
7223
7225
|
|
|
7226
|
+
function useSetCheckoutSuccess() {
|
|
7227
|
+
var _useCheckoutContext4 = useCheckoutContext(),
|
|
7228
|
+
setState = _useCheckoutContext4[1];
|
|
7229
|
+
|
|
7230
|
+
return function (checkoutSuccess) {
|
|
7231
|
+
return setState(function (draft) {
|
|
7232
|
+
draft.checkoutSuccess = checkoutSuccess;
|
|
7233
|
+
});
|
|
7234
|
+
};
|
|
7235
|
+
}
|
|
7236
|
+
|
|
7224
7237
|
function useCheckoutModel() {
|
|
7225
7238
|
var _useCheckoutState = useCheckoutState(),
|
|
7226
7239
|
checkoutState = _useCheckoutState.checkoutState,
|
|
7227
7240
|
widgetState = _useCheckoutState.widgetState,
|
|
7228
|
-
checkoutLocalization = _useCheckoutState.checkoutLocalization
|
|
7241
|
+
checkoutLocalization = _useCheckoutState.checkoutLocalization,
|
|
7242
|
+
checkoutSuccess = _useCheckoutState.checkoutSuccess;
|
|
7229
7243
|
|
|
7230
7244
|
return {
|
|
7231
7245
|
checkoutState: checkoutState,
|
|
7232
7246
|
widgetState: widgetState,
|
|
7233
7247
|
checkoutLocalization: checkoutLocalization,
|
|
7248
|
+
checkoutSuccess: checkoutSuccess,
|
|
7234
7249
|
setWidgetReadOnly: useSetWidgetReadonly(),
|
|
7235
|
-
setIsValid: useSetIsValid()
|
|
7250
|
+
setIsValid: useSetIsValid(),
|
|
7251
|
+
setCheckoutSuccess: useSetCheckoutSuccess()
|
|
7236
7252
|
};
|
|
7237
7253
|
}
|
|
7238
7254
|
|
|
@@ -8255,7 +8271,8 @@ function CheckoutProvider(_ref2) {
|
|
|
8255
8271
|
isValid: true,
|
|
8256
8272
|
isLoadingCheckoutData: isLoading
|
|
8257
8273
|
},
|
|
8258
|
-
isWidgetWatermarkEnabled: isWidgetWatermarkEnabled
|
|
8274
|
+
isWidgetWatermarkEnabled: isWidgetWatermarkEnabled,
|
|
8275
|
+
checkoutSuccess: false
|
|
8259
8276
|
};
|
|
8260
8277
|
return initialState; // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
8261
8278
|
}, [preferredBillingPeriod, billingCountryCode, checkout, isLoading, skipCheckoutSteps, billingInformation == null ? void 0 : (_billingInformation$t2 = billingInformation.taxDetails) == null ? void 0 : _billingInformation$t2.taxPercentage]);
|
|
@@ -12513,6 +12530,314 @@ function useSubmit(_ref) {
|
|
|
12513
12530
|
};
|
|
12514
12531
|
}
|
|
12515
12532
|
|
|
12533
|
+
function isZuoraLibraryAvailable() {
|
|
12534
|
+
return !!window.Zuora;
|
|
12535
|
+
}
|
|
12536
|
+
function loadZuoraLibrary() {
|
|
12537
|
+
var script = document.createElement('script');
|
|
12538
|
+
script.type = 'text/javascript';
|
|
12539
|
+
script.src = 'https://js.zuora.com/payment/v3/zuora.js';
|
|
12540
|
+
script.async = true;
|
|
12541
|
+
|
|
12542
|
+
script.onerror = function () {
|
|
12543
|
+
throw new Error('Failed to load Zuora library');
|
|
12544
|
+
};
|
|
12545
|
+
|
|
12546
|
+
document.head.appendChild(script);
|
|
12547
|
+
}
|
|
12548
|
+
function createZuoraPaymentFormConfig(createPaymentSession, onComplete, currency, billingCountryCode) {
|
|
12549
|
+
var AUTH_AMOUNT = '1';
|
|
12550
|
+
return {
|
|
12551
|
+
locale: billingCountryCode || 'en',
|
|
12552
|
+
region: (billingCountryCode == null ? void 0 : billingCountryCode.toUpperCase()) || 'US',
|
|
12553
|
+
currency: currency,
|
|
12554
|
+
amount: AUTH_AMOUNT,
|
|
12555
|
+
createPaymentSession: createPaymentSession,
|
|
12556
|
+
onComplete: onComplete
|
|
12557
|
+
};
|
|
12558
|
+
}
|
|
12559
|
+
|
|
12560
|
+
function useZuoraIntegration() {
|
|
12561
|
+
var _useStiggContext = useStiggContext(),
|
|
12562
|
+
stigg = _useStiggContext.stigg;
|
|
12563
|
+
|
|
12564
|
+
var _usePaymentStepModel = usePaymentStepModel(),
|
|
12565
|
+
setErrorMessage = _usePaymentStepModel.setErrorMessage;
|
|
12566
|
+
|
|
12567
|
+
var _usePlanStepModel = usePlanStepModel(),
|
|
12568
|
+
billingCountryCode = _usePlanStepModel.billingCountryCode;
|
|
12569
|
+
|
|
12570
|
+
var _useState = React.useState(false),
|
|
12571
|
+
isInitialized = _useState[0],
|
|
12572
|
+
setIsInitialized = _useState[1];
|
|
12573
|
+
|
|
12574
|
+
var _useCheckoutModel = useCheckoutModel(),
|
|
12575
|
+
checkoutState = _useCheckoutModel.checkoutState;
|
|
12576
|
+
|
|
12577
|
+
var _ref = checkoutState || {},
|
|
12578
|
+
billingIntegration = _ref.billingIntegration;
|
|
12579
|
+
|
|
12580
|
+
var createPaymentSession = React.useCallback( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee() {
|
|
12581
|
+
var _yield$stigg$createPa, token;
|
|
12582
|
+
|
|
12583
|
+
return runtime_1.wrap(function _callee$(_context) {
|
|
12584
|
+
while (1) {
|
|
12585
|
+
switch (_context.prev = _context.next) {
|
|
12586
|
+
case 0:
|
|
12587
|
+
if (!(!(checkoutState != null && checkoutState.customer.id) || !(checkoutState != null && checkoutState.plan.id))) {
|
|
12588
|
+
_context.next = 2;
|
|
12589
|
+
break;
|
|
12590
|
+
}
|
|
12591
|
+
|
|
12592
|
+
throw new Error('Customer and plan are required');
|
|
12593
|
+
|
|
12594
|
+
case 2:
|
|
12595
|
+
_context.next = 4;
|
|
12596
|
+
return stigg.createPaymentSession({
|
|
12597
|
+
planId: checkoutState.plan.id,
|
|
12598
|
+
billingCountryCode: billingCountryCode
|
|
12599
|
+
});
|
|
12600
|
+
|
|
12601
|
+
case 4:
|
|
12602
|
+
_yield$stigg$createPa = _context.sent;
|
|
12603
|
+
token = _yield$stigg$createPa.token;
|
|
12604
|
+
return _context.abrupt("return", token);
|
|
12605
|
+
|
|
12606
|
+
case 7:
|
|
12607
|
+
case "end":
|
|
12608
|
+
return _context.stop();
|
|
12609
|
+
}
|
|
12610
|
+
}
|
|
12611
|
+
}, _callee);
|
|
12612
|
+
})), [checkoutState, stigg, billingCountryCode]);
|
|
12613
|
+
var initializeZuora = React.useCallback(function () {
|
|
12614
|
+
try {
|
|
12615
|
+
if (!isZuoraLibraryAvailable()) {
|
|
12616
|
+
loadZuoraLibrary();
|
|
12617
|
+
}
|
|
12618
|
+
|
|
12619
|
+
setIsInitialized(true);
|
|
12620
|
+
} catch (err) {
|
|
12621
|
+
setErrorMessage('Failed to initialize Zuora');
|
|
12622
|
+
}
|
|
12623
|
+
}, [setIsInitialized, setErrorMessage]);
|
|
12624
|
+
React.useEffect(function () {
|
|
12625
|
+
if (billingIntegration) {
|
|
12626
|
+
var billingIdentifier = billingIntegration.billingIdentifier;
|
|
12627
|
+
|
|
12628
|
+
if (billingIdentifier === Stigg.BillingVendorIdentifier.Zuora) {
|
|
12629
|
+
void initializeZuora();
|
|
12630
|
+
}
|
|
12631
|
+
}
|
|
12632
|
+
}, [billingIntegration, initializeZuora]);
|
|
12633
|
+
var isZuoraIntegration = (billingIntegration == null ? void 0 : billingIntegration.billingIdentifier) === Stigg.BillingVendorIdentifier.Zuora;
|
|
12634
|
+
return {
|
|
12635
|
+
isZuoraIntegration: isZuoraIntegration,
|
|
12636
|
+
isInitialized: isInitialized,
|
|
12637
|
+
createPaymentSession: createPaymentSession
|
|
12638
|
+
};
|
|
12639
|
+
}
|
|
12640
|
+
|
|
12641
|
+
var delay$1 = function delay(ms) {
|
|
12642
|
+
return new Promise(function (res) {
|
|
12643
|
+
return setTimeout(res, ms);
|
|
12644
|
+
});
|
|
12645
|
+
};
|
|
12646
|
+
|
|
12647
|
+
function useZuoraSubmit(_ref) {
|
|
12648
|
+
var onCheckout = _ref.onCheckout,
|
|
12649
|
+
onCheckoutCompleted = _ref.onCheckoutCompleted,
|
|
12650
|
+
onSuccess = _ref.onSuccess,
|
|
12651
|
+
disableSuccessAnimation = _ref.disableSuccessAnimation;
|
|
12652
|
+
|
|
12653
|
+
var _useStiggContext = useStiggContext(),
|
|
12654
|
+
stigg = _useStiggContext.stigg;
|
|
12655
|
+
|
|
12656
|
+
var subscriptionState = useSubscriptionState();
|
|
12657
|
+
|
|
12658
|
+
var _useCheckoutModel = useCheckoutModel(),
|
|
12659
|
+
checkoutState = _useCheckoutModel.checkoutState,
|
|
12660
|
+
setWidgetReadOnly = _useCheckoutModel.setWidgetReadOnly,
|
|
12661
|
+
setCheckoutSuccess = _useCheckoutModel.setCheckoutSuccess;
|
|
12662
|
+
|
|
12663
|
+
var _usePaymentStepModel = usePaymentStepModel(),
|
|
12664
|
+
setErrorMessage = _usePaymentStepModel.setErrorMessage;
|
|
12665
|
+
|
|
12666
|
+
var handleZuoraSubmit = React.useCallback( /*#__PURE__*/function () {
|
|
12667
|
+
var _ref2 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee2(paymentMethodId) {
|
|
12668
|
+
var success, errorMessage, currentSubscriptionState, checkoutParams, checkoutAction, externalCheckoutResults, checkoutActionResults;
|
|
12669
|
+
return runtime_1.wrap(function _callee2$(_context2) {
|
|
12670
|
+
while (1) {
|
|
12671
|
+
switch (_context2.prev = _context2.next) {
|
|
12672
|
+
case 0:
|
|
12673
|
+
setWidgetReadOnly(true);
|
|
12674
|
+
success = true;
|
|
12675
|
+
currentSubscriptionState = subscriptionState;
|
|
12676
|
+
|
|
12677
|
+
if (currentSubscriptionState) {
|
|
12678
|
+
_context2.next = 8;
|
|
12679
|
+
break;
|
|
12680
|
+
}
|
|
12681
|
+
|
|
12682
|
+
success = false;
|
|
12683
|
+
errorMessage = 'Unexpected error, please contact support.';
|
|
12684
|
+
_context2.next = 30;
|
|
12685
|
+
break;
|
|
12686
|
+
|
|
12687
|
+
case 8:
|
|
12688
|
+
checkoutParams = _extends({}, currentSubscriptionState, {
|
|
12689
|
+
paymentMethodId: paymentMethodId
|
|
12690
|
+
});
|
|
12691
|
+
|
|
12692
|
+
checkoutAction = /*#__PURE__*/function () {
|
|
12693
|
+
var _ref3 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(params) {
|
|
12694
|
+
var applySubscriptionResults;
|
|
12695
|
+
return runtime_1.wrap(function _callee$(_context) {
|
|
12696
|
+
while (1) {
|
|
12697
|
+
switch (_context.prev = _context.next) {
|
|
12698
|
+
case 0:
|
|
12699
|
+
_context.prev = 0;
|
|
12700
|
+
_context.next = 3;
|
|
12701
|
+
return stigg.applySubscription(params);
|
|
12702
|
+
|
|
12703
|
+
case 3:
|
|
12704
|
+
applySubscriptionResults = _context.sent;
|
|
12705
|
+
return _context.abrupt("return", {
|
|
12706
|
+
success: true,
|
|
12707
|
+
results: applySubscriptionResults
|
|
12708
|
+
});
|
|
12709
|
+
|
|
12710
|
+
case 7:
|
|
12711
|
+
_context.prev = 7;
|
|
12712
|
+
_context.t0 = _context["catch"](0);
|
|
12713
|
+
console.error(_context.t0);
|
|
12714
|
+
return _context.abrupt("return", {
|
|
12715
|
+
success: false,
|
|
12716
|
+
errorMessage: (_context.t0 == null ? void 0 : _context.t0.message) || 'Failed to apply subscription'
|
|
12717
|
+
});
|
|
12718
|
+
|
|
12719
|
+
case 11:
|
|
12720
|
+
case "end":
|
|
12721
|
+
return _context.stop();
|
|
12722
|
+
}
|
|
12723
|
+
}
|
|
12724
|
+
}, _callee, null, [[0, 7]]);
|
|
12725
|
+
}));
|
|
12726
|
+
|
|
12727
|
+
return function checkoutAction(_x2) {
|
|
12728
|
+
return _ref3.apply(this, arguments);
|
|
12729
|
+
};
|
|
12730
|
+
}();
|
|
12731
|
+
|
|
12732
|
+
_context2.prev = 10;
|
|
12733
|
+
|
|
12734
|
+
if (!onCheckout) {
|
|
12735
|
+
_context2.next = 19;
|
|
12736
|
+
break;
|
|
12737
|
+
}
|
|
12738
|
+
|
|
12739
|
+
_context2.next = 14;
|
|
12740
|
+
return onCheckout({
|
|
12741
|
+
customerId: checkoutState.customer.id,
|
|
12742
|
+
checkoutParams: checkoutParams,
|
|
12743
|
+
checkoutAction: checkoutAction
|
|
12744
|
+
});
|
|
12745
|
+
|
|
12746
|
+
case 14:
|
|
12747
|
+
externalCheckoutResults = _context2.sent;
|
|
12748
|
+
|
|
12749
|
+
if (externalCheckoutResults.errorMessage) {
|
|
12750
|
+
errorMessage = externalCheckoutResults.errorMessage;
|
|
12751
|
+
}
|
|
12752
|
+
|
|
12753
|
+
success = success && externalCheckoutResults.success && !errorMessage;
|
|
12754
|
+
_context2.next = 24;
|
|
12755
|
+
break;
|
|
12756
|
+
|
|
12757
|
+
case 19:
|
|
12758
|
+
_context2.next = 21;
|
|
12759
|
+
return checkoutAction(checkoutParams);
|
|
12760
|
+
|
|
12761
|
+
case 21:
|
|
12762
|
+
checkoutActionResults = _context2.sent;
|
|
12763
|
+
|
|
12764
|
+
if (!checkoutActionResults.success && checkoutActionResults.errorMessage) {
|
|
12765
|
+
errorMessage = checkoutActionResults.errorMessage;
|
|
12766
|
+
}
|
|
12767
|
+
|
|
12768
|
+
success = checkoutActionResults.success && !errorMessage;
|
|
12769
|
+
|
|
12770
|
+
case 24:
|
|
12771
|
+
_context2.next = 30;
|
|
12772
|
+
break;
|
|
12773
|
+
|
|
12774
|
+
case 26:
|
|
12775
|
+
_context2.prev = 26;
|
|
12776
|
+
_context2.t0 = _context2["catch"](10);
|
|
12777
|
+
success = false;
|
|
12778
|
+
errorMessage = _context2.t0.message || 'Failed to process checkout';
|
|
12779
|
+
|
|
12780
|
+
case 30:
|
|
12781
|
+
if (!success) {
|
|
12782
|
+
_context2.next = 39;
|
|
12783
|
+
break;
|
|
12784
|
+
}
|
|
12785
|
+
|
|
12786
|
+
setCheckoutSuccess(true);
|
|
12787
|
+
|
|
12788
|
+
if (!onSuccess) {
|
|
12789
|
+
_context2.next = 37;
|
|
12790
|
+
break;
|
|
12791
|
+
}
|
|
12792
|
+
|
|
12793
|
+
onSuccess();
|
|
12794
|
+
|
|
12795
|
+
if (disableSuccessAnimation) {
|
|
12796
|
+
_context2.next = 37;
|
|
12797
|
+
break;
|
|
12798
|
+
}
|
|
12799
|
+
|
|
12800
|
+
_context2.next = 37;
|
|
12801
|
+
return delay$1(ANIMATION_DURATION);
|
|
12802
|
+
|
|
12803
|
+
case 37:
|
|
12804
|
+
_context2.next = 40;
|
|
12805
|
+
break;
|
|
12806
|
+
|
|
12807
|
+
case 39:
|
|
12808
|
+
setErrorMessage(errorMessage);
|
|
12809
|
+
|
|
12810
|
+
case 40:
|
|
12811
|
+
setWidgetReadOnly(false);
|
|
12812
|
+
_context2.next = 43;
|
|
12813
|
+
return onCheckoutCompleted({
|
|
12814
|
+
success: success,
|
|
12815
|
+
error: errorMessage
|
|
12816
|
+
});
|
|
12817
|
+
|
|
12818
|
+
case 43:
|
|
12819
|
+
return _context2.abrupt("return", {
|
|
12820
|
+
success: success,
|
|
12821
|
+
errorMessage: errorMessage
|
|
12822
|
+
});
|
|
12823
|
+
|
|
12824
|
+
case 44:
|
|
12825
|
+
case "end":
|
|
12826
|
+
return _context2.stop();
|
|
12827
|
+
}
|
|
12828
|
+
}
|
|
12829
|
+
}, _callee2, null, [[10, 26]]);
|
|
12830
|
+
}));
|
|
12831
|
+
|
|
12832
|
+
return function (_x) {
|
|
12833
|
+
return _ref2.apply(this, arguments);
|
|
12834
|
+
};
|
|
12835
|
+
}(), [stigg, subscriptionState, checkoutState, onCheckout, onCheckoutCompleted, onSuccess, disableSuccessAnimation, setWidgetReadOnly, setCheckoutSuccess, setErrorMessage]);
|
|
12836
|
+
return {
|
|
12837
|
+
handleZuoraSubmit: handleZuoraSubmit
|
|
12838
|
+
};
|
|
12839
|
+
}
|
|
12840
|
+
|
|
12516
12841
|
var WithSkeleton = function WithSkeleton(_ref) {
|
|
12517
12842
|
var isLoading = _ref.isLoading,
|
|
12518
12843
|
_ref$width = _ref.width,
|
|
@@ -13036,7 +13361,7 @@ var SummaryContainer = /*#__PURE__*/_styled(Box, {
|
|
|
13036
13361
|
})( {
|
|
13037
13362
|
name: "1w9aiz5",
|
|
13038
13363
|
styles: "width:100%;max-width:470px;flex:1.5",
|
|
13039
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAwB4C","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13364
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA0B4C","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { useZuoraIntegration } from '../steps/payment/zuora/useZuoraIntegration';\r\nimport { useZuoraSubmit } from '../steps/payment/zuora/useZuoraSubmit';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage, useNewPaymentMethod } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization, checkoutSuccess, widgetState } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { isZuoraIntegration } = useZuoraIntegration();\r\n    const isCheckoutCompleted = isCheckoutCompletedSuccessfully || checkoutSuccess;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit: handleStripeSubmit, isLoading: isStripeLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const { handleZuoraSubmit } = useZuoraSubmit({\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        disableSuccessAnimation,\r\n        onSuccess: () => {\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompleted) {\r\n            return;\r\n        }\r\n        let result;\r\n        if (isZuoraIntegration && !useNewPaymentMethod) {\r\n            result = await handleZuoraSubmit();\r\n        }\r\n        else {\r\n            result = await handleStripeSubmit(e);\r\n        }\r\n        const { errorMessage } = result || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    // This is sad\r\n    const isLoading = isZuoraIntegration && !useNewPaymentMethod ? widgetState.readOnly : isStripeLoading;\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade && !isZuoraIntegration;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            (!isLastStep || !isZuoraIntegration || (isZuoraIntegration && !useNewPaymentMethod)) && (React.createElement(Button, { \"$success\": isCheckoutCompleted, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompleted ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                })))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompleted && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13040
13365
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$p
|
|
13041
13366
|
});
|
|
13042
13367
|
var SummaryCard = /*#__PURE__*/_styled(Paper, {
|
|
@@ -13045,7 +13370,7 @@ var SummaryCard = /*#__PURE__*/_styled(Paper, {
|
|
|
13045
13370
|
})("background:", function (_ref) {
|
|
13046
13371
|
var theme = _ref.theme;
|
|
13047
13372
|
return theme.stigg.palette.backgroundHighlight;
|
|
13048
|
-
}, ";padding:16px;", mq.md, "{border-radius:10px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA6ByC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
|
|
13373
|
+
}, ";padding:16px;", mq.md, "{border-radius:10px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA+ByC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { useZuoraIntegration } from '../steps/payment/zuora/useZuoraIntegration';\r\nimport { useZuoraSubmit } from '../steps/payment/zuora/useZuoraSubmit';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage, useNewPaymentMethod } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization, checkoutSuccess, widgetState } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { isZuoraIntegration } = useZuoraIntegration();\r\n    const isCheckoutCompleted = isCheckoutCompletedSuccessfully || checkoutSuccess;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit: handleStripeSubmit, isLoading: isStripeLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const { handleZuoraSubmit } = useZuoraSubmit({\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        disableSuccessAnimation,\r\n        onSuccess: () => {\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompleted) {\r\n            return;\r\n        }\r\n        let result;\r\n        if (isZuoraIntegration && !useNewPaymentMethod) {\r\n            result = await handleZuoraSubmit();\r\n        }\r\n        else {\r\n            result = await handleStripeSubmit(e);\r\n        }\r\n        const { errorMessage } = result || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    // This is sad\r\n    const isLoading = isZuoraIntegration && !useNewPaymentMethod ? widgetState.readOnly : isStripeLoading;\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade && !isZuoraIntegration;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            (!isLastStep || !isZuoraIntegration || (isZuoraIntegration && !useNewPaymentMethod)) && (React.createElement(Button, { \"$success\": isCheckoutCompleted, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompleted ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                })))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompleted && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
|
|
13049
13374
|
SummaryCard.defaultProps = {
|
|
13050
13375
|
elevation: 0
|
|
13051
13376
|
};
|
|
@@ -13056,7 +13381,7 @@ var SummaryTitle = /*#__PURE__*/_styled(Typography, {
|
|
|
13056
13381
|
})( {
|
|
13057
13382
|
name: "1jcocwa",
|
|
13058
13383
|
styles: "margin-bottom:16px;font-weight:500",
|
|
13059
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAwCwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13384
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA0CwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { useZuoraIntegration } from '../steps/payment/zuora/useZuoraIntegration';\r\nimport { useZuoraSubmit } from '../steps/payment/zuora/useZuoraSubmit';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage, useNewPaymentMethod } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization, checkoutSuccess, widgetState } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { isZuoraIntegration } = useZuoraIntegration();\r\n    const isCheckoutCompleted = isCheckoutCompletedSuccessfully || checkoutSuccess;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit: handleStripeSubmit, isLoading: isStripeLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const { handleZuoraSubmit } = useZuoraSubmit({\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        disableSuccessAnimation,\r\n        onSuccess: () => {\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompleted) {\r\n            return;\r\n        }\r\n        let result;\r\n        if (isZuoraIntegration && !useNewPaymentMethod) {\r\n            result = await handleZuoraSubmit();\r\n        }\r\n        else {\r\n            result = await handleStripeSubmit(e);\r\n        }\r\n        const { errorMessage } = result || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    // This is sad\r\n    const isLoading = isZuoraIntegration && !useNewPaymentMethod ? widgetState.readOnly : isStripeLoading;\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade && !isZuoraIntegration;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            (!isLastStep || !isZuoraIntegration || (isZuoraIntegration && !useNewPaymentMethod)) && (React.createElement(Button, { \"$success\": isCheckoutCompleted, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompleted ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                })))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompleted && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13060
13385
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$p
|
|
13061
13386
|
});
|
|
13062
13387
|
|
|
@@ -13066,7 +13391,7 @@ var StyledDivider$1 = /*#__PURE__*/_styled(Divider$1, {
|
|
|
13066
13391
|
})( {
|
|
13067
13392
|
name: "1k6141t",
|
|
13068
13393
|
styles: "margin:16px 0",
|
|
13069
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA4CsC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13394
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA8CsC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { useZuoraIntegration } from '../steps/payment/zuora/useZuoraIntegration';\r\nimport { useZuoraSubmit } from '../steps/payment/zuora/useZuoraSubmit';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage, useNewPaymentMethod } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization, checkoutSuccess, widgetState } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { isZuoraIntegration } = useZuoraIntegration();\r\n    const isCheckoutCompleted = isCheckoutCompletedSuccessfully || checkoutSuccess;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit: handleStripeSubmit, isLoading: isStripeLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const { handleZuoraSubmit } = useZuoraSubmit({\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        disableSuccessAnimation,\r\n        onSuccess: () => {\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompleted) {\r\n            return;\r\n        }\r\n        let result;\r\n        if (isZuoraIntegration && !useNewPaymentMethod) {\r\n            result = await handleZuoraSubmit();\r\n        }\r\n        else {\r\n            result = await handleStripeSubmit(e);\r\n        }\r\n        const { errorMessage } = result || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    // This is sad\r\n    const isLoading = isZuoraIntegration && !useNewPaymentMethod ? widgetState.readOnly : isStripeLoading;\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade && !isZuoraIntegration;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            (!isLastStep || !isZuoraIntegration || (isZuoraIntegration && !useNewPaymentMethod)) && (React.createElement(Button, { \"$success\": isCheckoutCompleted, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompleted ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                })))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompleted && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13070
13395
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$p
|
|
13071
13396
|
});
|
|
13072
13397
|
|
|
@@ -13076,7 +13401,7 @@ var TotalDueText = /*#__PURE__*/_styled(Typography, {
|
|
|
13076
13401
|
})( {
|
|
13077
13402
|
name: "5bhc30",
|
|
13078
13403
|
styles: "margin-bottom:8px",
|
|
13079
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA+CwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13404
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAiDwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { useZuoraIntegration } from '../steps/payment/zuora/useZuoraIntegration';\r\nimport { useZuoraSubmit } from '../steps/payment/zuora/useZuoraSubmit';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, isWidgetWatermarkEnabled, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage, useNewPaymentMethod } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization, checkoutSuccess, widgetState } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { isZuoraIntegration } = useZuoraIntegration();\r\n    const isCheckoutCompleted = isCheckoutCompletedSuccessfully || checkoutSuccess;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit: handleStripeSubmit, isLoading: isStripeLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const { handleZuoraSubmit } = useZuoraSubmit({\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        disableSuccessAnimation,\r\n        onSuccess: () => {\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompleted) {\r\n            return;\r\n        }\r\n        let result;\r\n        if (isZuoraIntegration && !useNewPaymentMethod) {\r\n            result = await handleZuoraSubmit();\r\n        }\r\n        else {\r\n            result = await handleStripeSubmit(e);\r\n        }\r\n        const { errorMessage } = result || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    // This is sad\r\n    const isLoading = isZuoraIntegration && !useNewPaymentMethod ? widgetState.readOnly : isStripeLoading;\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade && !isZuoraIntegration;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            })),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            (!isLastStep || !isZuoraIntegration || (isZuoraIntegration && !useNewPaymentMethod)) && (React.createElement(Button, { \"$success\": isCheckoutCompleted, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompleted ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                })))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: isWidgetWatermarkEnabled, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompleted && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
13080
13405
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$p
|
|
13081
13406
|
});
|
|
13082
13407
|
|
|
@@ -13122,14 +13447,17 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13122
13447
|
setIsCheckoutCompletedSuccessfully = _useState[1];
|
|
13123
13448
|
|
|
13124
13449
|
var _usePaymentStepModel = usePaymentStepModel(),
|
|
13125
|
-
setErrorMessage = _usePaymentStepModel.setErrorMessage
|
|
13450
|
+
setErrorMessage = _usePaymentStepModel.setErrorMessage,
|
|
13451
|
+
useNewPaymentMethod = _usePaymentStepModel.useNewPaymentMethod;
|
|
13126
13452
|
|
|
13127
13453
|
var progressBar = useProgressBarModel();
|
|
13128
13454
|
var subscription = useSubscriptionModel();
|
|
13129
13455
|
|
|
13130
13456
|
var _useCheckoutModel = useCheckoutModel(),
|
|
13131
13457
|
checkoutState = _useCheckoutModel.checkoutState,
|
|
13132
|
-
checkoutLocalization = _useCheckoutModel.checkoutLocalization
|
|
13458
|
+
checkoutLocalization = _useCheckoutModel.checkoutLocalization,
|
|
13459
|
+
checkoutSuccess = _useCheckoutModel.checkoutSuccess,
|
|
13460
|
+
widgetState = _useCheckoutModel.widgetState;
|
|
13133
13461
|
|
|
13134
13462
|
var _ref4 = checkoutState || {},
|
|
13135
13463
|
plan = _ref4.plan,
|
|
@@ -13150,6 +13478,11 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13150
13478
|
|
|
13151
13479
|
var isLastStep = isFreeDowngrade || progressBar.isCheckoutComplete && progressBar.isLastStep;
|
|
13152
13480
|
|
|
13481
|
+
var _useZuoraIntegration = useZuoraIntegration(),
|
|
13482
|
+
isZuoraIntegration = _useZuoraIntegration.isZuoraIntegration;
|
|
13483
|
+
|
|
13484
|
+
var isCheckoutCompleted = isCheckoutCompletedSuccessfully || checkoutSuccess;
|
|
13485
|
+
|
|
13153
13486
|
var _usePreviewSubscripti = usePreviewSubscription({
|
|
13154
13487
|
onMockCheckoutPreview: onMockCheckoutPreview
|
|
13155
13488
|
}),
|
|
@@ -13166,18 +13499,28 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13166
13499
|
progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);
|
|
13167
13500
|
}
|
|
13168
13501
|
}),
|
|
13169
|
-
|
|
13170
|
-
|
|
13502
|
+
handleStripeSubmit = _useSubmit.handleSubmit,
|
|
13503
|
+
isStripeLoading = _useSubmit.isLoading;
|
|
13504
|
+
|
|
13505
|
+
var _useZuoraSubmit = useZuoraSubmit({
|
|
13506
|
+
onCheckout: onCheckout,
|
|
13507
|
+
onCheckoutCompleted: onCheckoutCompleted,
|
|
13508
|
+
disableSuccessAnimation: disableSuccessAnimation,
|
|
13509
|
+
onSuccess: function onSuccess() {
|
|
13510
|
+
progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);
|
|
13511
|
+
}
|
|
13512
|
+
}),
|
|
13513
|
+
handleZuoraSubmit = _useZuoraSubmit.handleZuoraSubmit;
|
|
13171
13514
|
|
|
13172
13515
|
var handleCheckout = /*#__PURE__*/function () {
|
|
13173
13516
|
var _ref6 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(e) {
|
|
13174
|
-
var _ref7, errorMessage;
|
|
13517
|
+
var result, _ref7, errorMessage;
|
|
13175
13518
|
|
|
13176
13519
|
return runtime_1.wrap(function _callee$(_context) {
|
|
13177
13520
|
while (1) {
|
|
13178
13521
|
switch (_context.prev = _context.next) {
|
|
13179
13522
|
case 0:
|
|
13180
|
-
if (!
|
|
13523
|
+
if (!isCheckoutCompleted) {
|
|
13181
13524
|
_context.next = 2;
|
|
13182
13525
|
break;
|
|
13183
13526
|
}
|
|
@@ -13185,22 +13528,28 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13185
13528
|
return _context.abrupt("return");
|
|
13186
13529
|
|
|
13187
13530
|
case 2:
|
|
13188
|
-
|
|
13189
|
-
|
|
13190
|
-
|
|
13191
|
-
case 4:
|
|
13192
|
-
_context.t0 = _context.sent;
|
|
13193
|
-
|
|
13194
|
-
if (_context.t0) {
|
|
13195
|
-
_context.next = 7;
|
|
13531
|
+
if (!(isZuoraIntegration && !useNewPaymentMethod)) {
|
|
13532
|
+
_context.next = 8;
|
|
13196
13533
|
break;
|
|
13197
13534
|
}
|
|
13198
13535
|
|
|
13199
|
-
_context.
|
|
13536
|
+
_context.next = 5;
|
|
13537
|
+
return handleZuoraSubmit();
|
|
13200
13538
|
|
|
13201
|
-
case
|
|
13202
|
-
|
|
13203
|
-
|
|
13539
|
+
case 5:
|
|
13540
|
+
result = _context.sent;
|
|
13541
|
+
_context.next = 11;
|
|
13542
|
+
break;
|
|
13543
|
+
|
|
13544
|
+
case 8:
|
|
13545
|
+
_context.next = 10;
|
|
13546
|
+
return handleStripeSubmit(e);
|
|
13547
|
+
|
|
13548
|
+
case 10:
|
|
13549
|
+
result = _context.sent;
|
|
13550
|
+
|
|
13551
|
+
case 11:
|
|
13552
|
+
_ref7 = result || {}, errorMessage = _ref7.errorMessage;
|
|
13204
13553
|
|
|
13205
13554
|
if (errorMessage) {
|
|
13206
13555
|
setErrorMessage(errorMessage);
|
|
@@ -13209,7 +13558,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13209
13558
|
setErrorMessage(undefined);
|
|
13210
13559
|
}
|
|
13211
13560
|
|
|
13212
|
-
case
|
|
13561
|
+
case 13:
|
|
13213
13562
|
case "end":
|
|
13214
13563
|
return _context.stop();
|
|
13215
13564
|
}
|
|
@@ -13220,7 +13569,10 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13220
13569
|
return function handleCheckout(_x) {
|
|
13221
13570
|
return _ref6.apply(this, arguments);
|
|
13222
13571
|
};
|
|
13223
|
-
}();
|
|
13572
|
+
}(); // This is sad
|
|
13573
|
+
|
|
13574
|
+
|
|
13575
|
+
var isLoading = isZuoraIntegration && !useNewPaymentMethod ? widgetState.readOnly : isStripeLoading;
|
|
13224
13576
|
|
|
13225
13577
|
var onCheckoutClick = /*#__PURE__*/function () {
|
|
13226
13578
|
var _ref8 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee2(e) {
|
|
@@ -13269,7 +13621,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13269
13621
|
recurringInvoice = _ref9.recurringInvoice;
|
|
13270
13622
|
|
|
13271
13623
|
var checkoutHasChanges = !!subscriptionPreview && (!!(immediateInvoice != null && immediateInvoice.proration) || !!subscriptionPreview.hasScheduledUpdates);
|
|
13272
|
-
var showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;
|
|
13624
|
+
var showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade && !isZuoraIntegration;
|
|
13273
13625
|
var showDiscountLine = !!(recurringInvoice != null && recurringInvoice.discountDetails) && !isFreeDowngrade;
|
|
13274
13626
|
var hasDiscounts = showPromotionCodeLine || showDiscountLine;
|
|
13275
13627
|
var hasPayAsYouGoCharges = usageCharges.some(function (price) {
|
|
@@ -13458,8 +13810,8 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13458
13810
|
isFetchingSubscriptionPreview: isFetchingSubscriptionPreview,
|
|
13459
13811
|
checkoutLocalization: checkoutLocalization,
|
|
13460
13812
|
billingPeriod: subscription.billingPeriod
|
|
13461
|
-
}), React__default.createElement(Button, {
|
|
13462
|
-
"$success":
|
|
13813
|
+
}), (!isLastStep || !isZuoraIntegration || isZuoraIntegration && !useNewPaymentMethod) && React__default.createElement(Button, {
|
|
13814
|
+
"$success": isCheckoutCompleted,
|
|
13463
13815
|
"$error": isLastStep && isFreeDowngrade,
|
|
13464
13816
|
disabled: isLoading || isFetchingSubscriptionPreview || progressBar.progressBarState.isDisabled || isLastStep && !checkoutHasChanges,
|
|
13465
13817
|
className: "stigg-checkout-summary-cta-button",
|
|
@@ -13482,7 +13834,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13482
13834
|
style: {
|
|
13483
13835
|
display: 'flex'
|
|
13484
13836
|
}
|
|
13485
|
-
},
|
|
13837
|
+
}, isCheckoutCompleted ? React__default.createElement(Icon, {
|
|
13486
13838
|
icon: "Check",
|
|
13487
13839
|
style: {
|
|
13488
13840
|
display: 'contents'
|
|
@@ -13506,7 +13858,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
13506
13858
|
display: 'flex',
|
|
13507
13859
|
justifyContent: 'center'
|
|
13508
13860
|
}
|
|
13509
|
-
}), !disableSuccessAnimation &&
|
|
13861
|
+
}), !disableSuccessAnimation && isCheckoutCompleted && React__default.createElement(CheckoutSuccess, {
|
|
13510
13862
|
checkoutLocalization: checkoutLocalization
|
|
13511
13863
|
}));
|
|
13512
13864
|
};
|
|
@@ -13797,6 +14149,170 @@ var NewPaymentMethodContainer = /*#__PURE__*/styled(PaymentMethodContainer)(_tem
|
|
|
13797
14149
|
var PaymentMethodLayoutContainer = /*#__PURE__*/styled(Grid)(_templateObject4 || (_templateObject4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n flex: 1;\n gap: 12px;\n"])));
|
|
13798
14150
|
var PaymentMethodTextContainer = /*#__PURE__*/styled(Grid)(_templateObject5 || (_templateObject5 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n"])));
|
|
13799
14151
|
|
|
14152
|
+
var _templateObject$8, _templateObject2$3, _templateObject3$3, _templateObject4$1;
|
|
14153
|
+
var Container$1 = /*#__PURE__*/styled(Box)(_templateObject$8 || (_templateObject$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: relative;\n max-width: 500px;\n"])));
|
|
14154
|
+
var PaymentContainer = /*#__PURE__*/styled(Box)(_templateObject2$3 || (_templateObject2$3 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n opacity: ", ";\n pointer-events: ", ";\n"])), function (_ref) {
|
|
14155
|
+
var $showLoading = _ref.$showLoading;
|
|
14156
|
+
return $showLoading ? 0.6 : 1;
|
|
14157
|
+
}, function (_ref2) {
|
|
14158
|
+
var $showLoading = _ref2.$showLoading;
|
|
14159
|
+
return $showLoading ? 'none' : 'auto';
|
|
14160
|
+
});
|
|
14161
|
+
var LoadingOverlay = /*#__PURE__*/styled(Box)(_templateObject3$3 || (_templateObject3$3 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: absolute;\n top: 40px;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: rgba(255, 255, 255, 0.8);\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 4px;\n z-index: 10;\n"])));
|
|
14162
|
+
var LoadingContent = /*#__PURE__*/styled(Box)(_templateObject4$1 || (_templateObject4$1 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 12px;\n"])));
|
|
14163
|
+
function ZuoraPaymentForm(_ref3) {
|
|
14164
|
+
var _checkoutState$plan, _checkoutState$plan$p, _checkoutState$plan$p2;
|
|
14165
|
+
|
|
14166
|
+
var onCheckout = _ref3.onCheckout,
|
|
14167
|
+
onCheckoutCompleted = _ref3.onCheckoutCompleted;
|
|
14168
|
+
|
|
14169
|
+
var _useZuoraIntegration = useZuoraIntegration(),
|
|
14170
|
+
isZuoraIntegration = _useZuoraIntegration.isZuoraIntegration,
|
|
14171
|
+
isInitialized = _useZuoraIntegration.isInitialized,
|
|
14172
|
+
createPaymentSession = _useZuoraIntegration.createPaymentSession;
|
|
14173
|
+
|
|
14174
|
+
var _usePaymentStepModel = usePaymentStepModel(),
|
|
14175
|
+
setErrorMessage = _usePaymentStepModel.setErrorMessage;
|
|
14176
|
+
|
|
14177
|
+
var _usePlanStepModel = usePlanStepModel(),
|
|
14178
|
+
billingCountryCode = _usePlanStepModel.billingCountryCode;
|
|
14179
|
+
|
|
14180
|
+
var _useCheckoutModel = useCheckoutModel(),
|
|
14181
|
+
checkoutState = _useCheckoutModel.checkoutState,
|
|
14182
|
+
widgetState = _useCheckoutModel.widgetState;
|
|
14183
|
+
|
|
14184
|
+
var _useZuoraSubmit = useZuoraSubmit({
|
|
14185
|
+
onCheckout: onCheckout,
|
|
14186
|
+
onCheckoutCompleted: onCheckoutCompleted
|
|
14187
|
+
}),
|
|
14188
|
+
handleZuoraSubmit = _useZuoraSubmit.handleZuoraSubmit;
|
|
14189
|
+
|
|
14190
|
+
var hasRenderedRef = React.useRef(false);
|
|
14191
|
+
|
|
14192
|
+
var _React$useState = React__default.useState(false),
|
|
14193
|
+
paymentFormLoading = _React$useState[0],
|
|
14194
|
+
setPaymentFormLoading = _React$useState[1];
|
|
14195
|
+
|
|
14196
|
+
var currency = (checkoutState == null ? void 0 : (_checkoutState$plan = checkoutState.plan) == null ? void 0 : (_checkoutState$plan$p = _checkoutState$plan.pricePoints) == null ? void 0 : (_checkoutState$plan$p2 = _checkoutState$plan$p[0]) == null ? void 0 : _checkoutState$plan$p2.currency) || Stigg.Currency.Usd;
|
|
14197
|
+
|
|
14198
|
+
var _checkoutState$billin = checkoutState == null ? void 0 : checkoutState.billingIntegration.billingCredentials,
|
|
14199
|
+
publishableKey = _checkoutState$billin.publishableKey;
|
|
14200
|
+
|
|
14201
|
+
var handleZuoraComplete = React.useCallback( /*#__PURE__*/function () {
|
|
14202
|
+
var _ref4 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(result) {
|
|
14203
|
+
var _result$error, errorMessage;
|
|
14204
|
+
|
|
14205
|
+
return runtime_1.wrap(function _callee$(_context) {
|
|
14206
|
+
while (1) {
|
|
14207
|
+
switch (_context.prev = _context.next) {
|
|
14208
|
+
case 0:
|
|
14209
|
+
if (!(!result.success || !result.paymentMethodId)) {
|
|
14210
|
+
_context.next = 6;
|
|
14211
|
+
break;
|
|
14212
|
+
}
|
|
14213
|
+
|
|
14214
|
+
errorMessage = ((_result$error = result.error) == null ? void 0 : _result$error.message) || 'Payment failed';
|
|
14215
|
+
setErrorMessage(errorMessage);
|
|
14216
|
+
_context.next = 5;
|
|
14217
|
+
return onCheckoutCompleted({
|
|
14218
|
+
success: false,
|
|
14219
|
+
error: errorMessage
|
|
14220
|
+
});
|
|
14221
|
+
|
|
14222
|
+
case 5:
|
|
14223
|
+
return _context.abrupt("return");
|
|
14224
|
+
|
|
14225
|
+
case 6:
|
|
14226
|
+
_context.next = 8;
|
|
14227
|
+
return handleZuoraSubmit(result.paymentMethodId);
|
|
14228
|
+
|
|
14229
|
+
case 8:
|
|
14230
|
+
case "end":
|
|
14231
|
+
return _context.stop();
|
|
14232
|
+
}
|
|
14233
|
+
}
|
|
14234
|
+
}, _callee);
|
|
14235
|
+
}));
|
|
14236
|
+
|
|
14237
|
+
return function (_x) {
|
|
14238
|
+
return _ref4.apply(this, arguments);
|
|
14239
|
+
};
|
|
14240
|
+
}(), [handleZuoraSubmit, setErrorMessage, onCheckoutCompleted]);
|
|
14241
|
+
React.useEffect(function () {
|
|
14242
|
+
var renderZuoraForm = /*#__PURE__*/function () {
|
|
14243
|
+
var _ref5 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee2() {
|
|
14244
|
+
var zuora, config, paymentForm;
|
|
14245
|
+
return runtime_1.wrap(function _callee2$(_context2) {
|
|
14246
|
+
while (1) {
|
|
14247
|
+
switch (_context2.prev = _context2.next) {
|
|
14248
|
+
case 0:
|
|
14249
|
+
if (!(!isInitialized || hasRenderedRef.current)) {
|
|
14250
|
+
_context2.next = 2;
|
|
14251
|
+
break;
|
|
14252
|
+
}
|
|
14253
|
+
|
|
14254
|
+
return _context2.abrupt("return");
|
|
14255
|
+
|
|
14256
|
+
case 2:
|
|
14257
|
+
setPaymentFormLoading(true);
|
|
14258
|
+
setErrorMessage(undefined);
|
|
14259
|
+
_context2.prev = 4;
|
|
14260
|
+
hasRenderedRef.current = true;
|
|
14261
|
+
zuora = window.Zuora(publishableKey);
|
|
14262
|
+
config = createZuoraPaymentFormConfig(createPaymentSession, handleZuoraComplete, currency, billingCountryCode);
|
|
14263
|
+
_context2.next = 10;
|
|
14264
|
+
return zuora.createPaymentForm(config);
|
|
14265
|
+
|
|
14266
|
+
case 10:
|
|
14267
|
+
paymentForm = _context2.sent;
|
|
14268
|
+
paymentForm.mount('#zuora_payment');
|
|
14269
|
+
_context2.next = 18;
|
|
14270
|
+
break;
|
|
14271
|
+
|
|
14272
|
+
case 14:
|
|
14273
|
+
_context2.prev = 14;
|
|
14274
|
+
_context2.t0 = _context2["catch"](4);
|
|
14275
|
+
hasRenderedRef.current = false;
|
|
14276
|
+
setErrorMessage('Failed to render Zuora payment form');
|
|
14277
|
+
|
|
14278
|
+
case 18:
|
|
14279
|
+
_context2.prev = 18;
|
|
14280
|
+
setPaymentFormLoading(false);
|
|
14281
|
+
return _context2.finish(18);
|
|
14282
|
+
|
|
14283
|
+
case 21:
|
|
14284
|
+
case "end":
|
|
14285
|
+
return _context2.stop();
|
|
14286
|
+
}
|
|
14287
|
+
}
|
|
14288
|
+
}, _callee2, null, [[4, 14, 18, 21]]);
|
|
14289
|
+
}));
|
|
14290
|
+
|
|
14291
|
+
return function renderZuoraForm() {
|
|
14292
|
+
return _ref5.apply(this, arguments);
|
|
14293
|
+
};
|
|
14294
|
+
}();
|
|
14295
|
+
|
|
14296
|
+
void renderZuoraForm();
|
|
14297
|
+
return function () {
|
|
14298
|
+
hasRenderedRef.current = false;
|
|
14299
|
+
}; // Only depend on isInitialized to prevent multiple form renders
|
|
14300
|
+
// createPaymentSession and handleZuoraComplete are intentionally omitted
|
|
14301
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
14302
|
+
}, [isInitialized]);
|
|
14303
|
+
|
|
14304
|
+
if (!isZuoraIntegration) {
|
|
14305
|
+
return null;
|
|
14306
|
+
}
|
|
14307
|
+
|
|
14308
|
+
return React__default.createElement(Container$1, null, React__default.createElement(PaymentContainer, {
|
|
14309
|
+
id: "zuora_payment",
|
|
14310
|
+
"$showLoading": widgetState.readOnly || paymentFormLoading
|
|
14311
|
+
}), (widgetState.readOnly || paymentFormLoading) && React__default.createElement(LoadingOverlay, null, React__default.createElement(LoadingContent, null, React__default.createElement(CircularProgress, {
|
|
14312
|
+
size: 28
|
|
14313
|
+
}))));
|
|
14314
|
+
}
|
|
14315
|
+
|
|
13800
14316
|
function PaymentMethodLayout(_ref) {
|
|
13801
14317
|
var checked = _ref.checked,
|
|
13802
14318
|
text = _ref.text,
|
|
@@ -13849,7 +14365,13 @@ function NewPaymentMethod(_ref3) {
|
|
|
13849
14365
|
readOnly = _ref3.readOnly,
|
|
13850
14366
|
checkoutLocalization = _ref3.checkoutLocalization,
|
|
13851
14367
|
onBillingAddressChange = _ref3.onBillingAddressChange,
|
|
13852
|
-
collectPhoneNumber = _ref3.collectPhoneNumber
|
|
14368
|
+
collectPhoneNumber = _ref3.collectPhoneNumber,
|
|
14369
|
+
onCheckout = _ref3.onCheckout,
|
|
14370
|
+
onCheckoutCompleted = _ref3.onCheckoutCompleted;
|
|
14371
|
+
|
|
14372
|
+
var _useZuoraIntegration = useZuoraIntegration(),
|
|
14373
|
+
isZuoraIntegration = _useZuoraIntegration.isZuoraIntegration;
|
|
14374
|
+
|
|
13853
14375
|
return React__default.createElement(NewPaymentMethodContainer, {
|
|
13854
14376
|
item: true,
|
|
13855
14377
|
"$hideBorders": !hasExistingPaymentMethod,
|
|
@@ -13863,17 +14385,22 @@ function NewPaymentMethod(_ref3) {
|
|
|
13863
14385
|
}, checkoutLocalization.newPaymentMethodText)
|
|
13864
14386
|
}), React__default.createElement(Collapse, {
|
|
13865
14387
|
"in": checked
|
|
13866
|
-
}, React__default.createElement(
|
|
14388
|
+
}, isZuoraIntegration ? React__default.createElement(ZuoraPaymentForm, {
|
|
14389
|
+
onCheckout: onCheckout,
|
|
14390
|
+
onCheckoutCompleted: onCheckoutCompleted
|
|
14391
|
+
}) : React__default.createElement(StripePaymentForm, {
|
|
13867
14392
|
onBillingAddressChange: onBillingAddressChange,
|
|
13868
14393
|
collectPhoneNumber: collectPhoneNumber
|
|
13869
14394
|
})));
|
|
13870
14395
|
}
|
|
13871
14396
|
|
|
13872
|
-
var _templateObject$
|
|
13873
|
-
var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$
|
|
14397
|
+
var _templateObject$9;
|
|
14398
|
+
var PaymentContainer$1 = /*#__PURE__*/styled(Grid)(_templateObject$9 || (_templateObject$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n"])));
|
|
13874
14399
|
function PaymentStep(_ref) {
|
|
13875
14400
|
var onBillingAddressChange = _ref.onBillingAddressChange,
|
|
13876
|
-
collectPhoneNumber = _ref.collectPhoneNumber
|
|
14401
|
+
collectPhoneNumber = _ref.collectPhoneNumber,
|
|
14402
|
+
onCheckout = _ref.onCheckout,
|
|
14403
|
+
onCheckoutCompleted = _ref.onCheckoutCompleted;
|
|
13877
14404
|
|
|
13878
14405
|
var _useCheckoutModel = useCheckoutModel(),
|
|
13879
14406
|
checkoutState = _useCheckoutModel.checkoutState,
|
|
@@ -13898,7 +14425,7 @@ function PaymentStep(_ref) {
|
|
|
13898
14425
|
setUseNewPaymentMethod(openNewPaymentMethod);
|
|
13899
14426
|
};
|
|
13900
14427
|
|
|
13901
|
-
return React__default.createElement(PaymentContainer, {
|
|
14428
|
+
return React__default.createElement(PaymentContainer$1, {
|
|
13902
14429
|
container: true
|
|
13903
14430
|
}, !!errorMessage && React__default.createElement(Alert, {
|
|
13904
14431
|
severity: "error",
|
|
@@ -13923,7 +14450,9 @@ function PaymentStep(_ref) {
|
|
|
13923
14450
|
return handleOnSelect(true);
|
|
13924
14451
|
},
|
|
13925
14452
|
onBillingAddressChange: onBillingAddressChange,
|
|
13926
|
-
collectPhoneNumber: collectPhoneNumber
|
|
14453
|
+
collectPhoneNumber: collectPhoneNumber,
|
|
14454
|
+
onCheckout: onCheckout,
|
|
14455
|
+
onCheckoutCompleted: onCheckoutCompleted
|
|
13927
14456
|
}));
|
|
13928
14457
|
}
|
|
13929
14458
|
|
|
@@ -14126,8 +14655,8 @@ function BillingPeriodPicker$1(_ref2) {
|
|
|
14126
14655
|
})));
|
|
14127
14656
|
}
|
|
14128
14657
|
|
|
14129
|
-
var _templateObject$
|
|
14130
|
-
var StyledPlanCharge = /*#__PURE__*/styled.div(_templateObject$
|
|
14658
|
+
var _templateObject$a;
|
|
14659
|
+
var StyledPlanCharge = /*#__PURE__*/styled.div(_templateObject$a || (_templateObject$a = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n min-height: 60px;\n margin-top: 16px;\n flex-direction: column;\n\n ", " {\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n }\n"])), mq.md);
|
|
14131
14660
|
|
|
14132
14661
|
var getValidationText = function getValidationText(charge, quantity) {
|
|
14133
14662
|
var minUnitQuantity = charge.minUnitQuantity,
|
|
@@ -14493,7 +15022,9 @@ var DowngradeToFreePlan = function DowngradeToFreePlan(_ref3) {
|
|
|
14493
15022
|
var getStepProps = function getStepProps(currentStep, _ref) {
|
|
14494
15023
|
var onBillingAddressChange = _ref.onBillingAddressChange,
|
|
14495
15024
|
onChangePlan = _ref.onChangePlan,
|
|
14496
|
-
collectPhoneNumber = _ref.collectPhoneNumber
|
|
15025
|
+
collectPhoneNumber = _ref.collectPhoneNumber,
|
|
15026
|
+
onCheckout = _ref.onCheckout,
|
|
15027
|
+
onCheckoutCompleted = _ref.onCheckoutCompleted;
|
|
14497
15028
|
|
|
14498
15029
|
switch (currentStep.key) {
|
|
14499
15030
|
case CheckoutStepKey.PLAN:
|
|
@@ -14512,7 +15043,9 @@ var getStepProps = function getStepProps(currentStep, _ref) {
|
|
|
14512
15043
|
return {
|
|
14513
15044
|
content: React__default.createElement(PaymentStep, {
|
|
14514
15045
|
onBillingAddressChange: onBillingAddressChange,
|
|
14515
|
-
collectPhoneNumber: collectPhoneNumber
|
|
15046
|
+
collectPhoneNumber: collectPhoneNumber,
|
|
15047
|
+
onCheckout: onCheckout,
|
|
15048
|
+
onCheckoutCompleted: onCheckoutCompleted
|
|
14516
15049
|
})
|
|
14517
15050
|
};
|
|
14518
15051
|
|
|
@@ -14562,7 +15095,9 @@ function CheckoutContainer(_ref2) {
|
|
|
14562
15095
|
var _getStepProps = getStepProps(currentStep, {
|
|
14563
15096
|
onBillingAddressChange: onBillingAddressChange,
|
|
14564
15097
|
onChangePlan: onChangePlan,
|
|
14565
|
-
collectPhoneNumber: collectPhoneNumber
|
|
15098
|
+
collectPhoneNumber: collectPhoneNumber,
|
|
15099
|
+
onCheckout: onCheckout,
|
|
15100
|
+
onCheckoutCompleted: onCheckoutCompleted
|
|
14566
15101
|
}),
|
|
14567
15102
|
content = _getStepProps.content;
|
|
14568
15103
|
|