2021-06-17 17:08:22 +02:00
|
|
|
import React, { ReactElement, useEffect, useState } from 'react';
|
2021-06-01 11:01:38 +02:00
|
|
|
import { react2angular } from 'react2angular';
|
|
|
|
import { Loader } from '../base/loader';
|
|
|
|
import { StripeModal } from './stripe/stripe-modal';
|
|
|
|
import { PayZenModal } from './payzen/payzen-modal';
|
2021-04-09 09:03:59 +02:00
|
|
|
import { IApplication } from '../../models/application';
|
2021-05-21 18:25:18 +02:00
|
|
|
import { ShoppingCart } from '../../models/payment';
|
2021-04-09 09:03:59 +02:00
|
|
|
import { User } from '../../models/user';
|
|
|
|
import { PaymentSchedule } from '../../models/payment-schedule';
|
2021-06-17 17:08:22 +02:00
|
|
|
import { Setting, SettingName } from '../../models/setting';
|
2021-06-01 11:01:38 +02:00
|
|
|
import { Invoice } from '../../models/invoice';
|
|
|
|
import SettingAPI from '../../api/setting';
|
|
|
|
import { useTranslation } from 'react-i18next';
|
2021-04-09 09:03:59 +02:00
|
|
|
|
|
|
|
declare var Application: IApplication;
|
|
|
|
|
|
|
|
interface PaymentModalProps {
|
|
|
|
isOpen: boolean,
|
|
|
|
toggleModal: () => void,
|
2021-06-01 11:01:38 +02:00
|
|
|
afterSuccess: (result: Invoice|PaymentSchedule) => void,
|
|
|
|
onError: (message: string) => void,
|
2021-05-21 18:25:18 +02:00
|
|
|
cart: ShoppingCart,
|
2021-04-09 09:03:59 +02:00
|
|
|
currentUser: User,
|
|
|
|
schedule: PaymentSchedule,
|
|
|
|
customer: User
|
|
|
|
}
|
|
|
|
|
2021-04-09 12:09:54 +02:00
|
|
|
/**
|
|
|
|
* This component open a modal dialog for the configured payment gateway, allowing the user to input his card data
|
|
|
|
* to process an online payment.
|
|
|
|
*/
|
2021-06-01 11:01:38 +02:00
|
|
|
const PaymentModal: React.FC<PaymentModalProps> = ({ isOpen, toggleModal, afterSuccess, onError, currentUser, schedule , cart, customer }) => {
|
|
|
|
const { t } = useTranslation('shared');
|
2021-06-17 17:08:22 +02:00
|
|
|
|
|
|
|
const [gateway, setGateway] = useState<Setting>(null);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
SettingAPI.get(SettingName.PaymentGateway)
|
|
|
|
.then(setting => setGateway(setting))
|
|
|
|
.catch(error => onError(error));
|
|
|
|
}, []);
|
2021-04-09 09:03:59 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Render the Stripe payment modal
|
|
|
|
*/
|
|
|
|
const renderStripeModal = (): ReactElement => {
|
|
|
|
return <StripeModal isOpen={isOpen}
|
|
|
|
toggleModal={toggleModal}
|
|
|
|
afterSuccess={afterSuccess}
|
2021-05-21 18:25:18 +02:00
|
|
|
cart={cart}
|
2021-04-09 09:03:59 +02:00
|
|
|
currentUser={currentUser}
|
|
|
|
schedule={schedule}
|
|
|
|
customer={customer} />
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Render the PayZen payment modal
|
|
|
|
*/
|
|
|
|
const renderPayZenModal = (): ReactElement => {
|
|
|
|
return <PayZenModal isOpen={isOpen}
|
|
|
|
toggleModal={toggleModal}
|
|
|
|
afterSuccess={afterSuccess}
|
2021-05-21 18:25:18 +02:00
|
|
|
cart={cart}
|
2021-04-09 09:03:59 +02:00
|
|
|
currentUser={currentUser}
|
|
|
|
schedule={schedule}
|
|
|
|
customer={customer} />
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine which gateway is enabled and return the appropriate payment modal
|
|
|
|
*/
|
2021-06-17 17:08:22 +02:00
|
|
|
if (gateway === null || !isOpen) return <div/>;
|
|
|
|
|
2021-04-09 09:03:59 +02:00
|
|
|
switch (gateway.value) {
|
|
|
|
case 'stripe':
|
|
|
|
return renderStripeModal();
|
|
|
|
case 'payzen':
|
|
|
|
return renderPayZenModal();
|
2021-06-01 11:01:38 +02:00
|
|
|
case null:
|
|
|
|
case undefined:
|
|
|
|
onError(t('app.shared.payment_modal.online_payment_disabled'));
|
|
|
|
return <div />;
|
2021-04-09 09:03:59 +02:00
|
|
|
default:
|
2021-06-01 11:01:38 +02:00
|
|
|
onError(t('app.shared.payment_modal.unexpected_error'));
|
2021-04-09 09:03:59 +02:00
|
|
|
console.error(`[PaymentModal] Unimplemented gateway: ${gateway.value}`);
|
2021-06-01 11:01:38 +02:00
|
|
|
return <div />;
|
2021-04-09 09:03:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-06-01 11:01:38 +02:00
|
|
|
const PaymentModalWrapper: React.FC<PaymentModalProps> = ({ isOpen, toggleModal, afterSuccess, onError, currentUser, schedule , cart, customer }) => {
|
2021-04-09 09:03:59 +02:00
|
|
|
return (
|
|
|
|
<Loader>
|
2021-06-01 11:01:38 +02:00
|
|
|
<PaymentModal isOpen={isOpen} toggleModal={toggleModal} afterSuccess={afterSuccess} onError={onError} currentUser={currentUser} schedule={schedule} cart={cart} customer={customer} />
|
2021-04-09 09:03:59 +02:00
|
|
|
</Loader>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-06-01 11:01:38 +02:00
|
|
|
Application.Components.component('paymentModal', react2angular(PaymentModalWrapper, ['isOpen', 'toggleModal', 'afterSuccess', 'onError', 'currentUser', 'schedule', 'cart', 'customer']));
|