2021-06-04 18:26:20 +02:00
|
|
|
import React, { ReactElement, useEffect, useState } from 'react';
|
|
|
|
import { Loader } from '../base/loader';
|
|
|
|
import { StripeCardUpdateModal } from './stripe/stripe-card-update-modal';
|
|
|
|
import { PayzenCardUpdateModal } from './payzen/payzen-card-update-modal';
|
|
|
|
import { User } from '../../models/user';
|
|
|
|
import { PaymentSchedule } from '../../models/payment-schedule';
|
|
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
|
|
|
|
interface UpdateCardModalProps {
|
|
|
|
isOpen: boolean,
|
|
|
|
toggleModal: () => void,
|
|
|
|
afterSuccess: () => void,
|
|
|
|
onError: (message: string) => void,
|
|
|
|
schedule: PaymentSchedule,
|
|
|
|
operator: User
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This component open a modal dialog for the configured payment gateway, allowing the user to input his card data
|
|
|
|
* to process an online payment.
|
|
|
|
*/
|
|
|
|
const UpdateCardModalComponent: React.FC<UpdateCardModalProps> = ({ isOpen, toggleModal, afterSuccess, onError, operator, schedule }) => {
|
|
|
|
const { t } = useTranslation('shared');
|
|
|
|
const [gateway, setGateway] = useState<string>('');
|
|
|
|
|
|
|
|
useEffect(() => {
|
2022-01-03 17:13:35 +01:00
|
|
|
setGateway(schedule.gateway);
|
2021-06-04 18:26:20 +02:00
|
|
|
}, [schedule]);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Render the Stripe update-card modal
|
|
|
|
*/
|
|
|
|
const renderStripeModal = (): ReactElement => {
|
|
|
|
return <StripeCardUpdateModal isOpen={isOpen}
|
2021-07-01 12:34:10 +02:00
|
|
|
toggleModal={toggleModal}
|
|
|
|
onSuccess={afterSuccess}
|
|
|
|
operator={operator}
|
|
|
|
schedule={schedule} />;
|
|
|
|
};
|
2021-06-04 18:26:20 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Render the PayZen update-card modal
|
2022-01-03 17:13:35 +01:00
|
|
|
*/
|
2021-06-04 18:26:20 +02:00
|
|
|
const renderPayZenModal = (): ReactElement => {
|
|
|
|
return <PayzenCardUpdateModal isOpen={isOpen}
|
2021-07-01 12:34:10 +02:00
|
|
|
toggleModal={toggleModal}
|
|
|
|
onSuccess={afterSuccess}
|
|
|
|
operator={operator}
|
|
|
|
schedule={schedule} />;
|
|
|
|
};
|
2021-06-04 18:26:20 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine which gateway is in use with the current schedule and return the appropriate modal
|
|
|
|
*/
|
|
|
|
|
|
|
|
switch (gateway) {
|
2022-01-03 17:13:35 +01:00
|
|
|
case 'Stripe':
|
2021-06-04 18:26:20 +02:00
|
|
|
return renderStripeModal();
|
2022-01-03 17:13:35 +01:00
|
|
|
case 'PayZen':
|
2021-06-04 18:26:20 +02:00
|
|
|
return renderPayZenModal();
|
|
|
|
case '':
|
2022-01-05 15:58:33 +01:00
|
|
|
case undefined:
|
2021-06-04 18:26:20 +02:00
|
|
|
return <div/>;
|
|
|
|
default:
|
|
|
|
onError(t('app.shared.update_card_modal.unexpected_error'));
|
2022-01-03 17:13:35 +01:00
|
|
|
console.error(`[UpdateCardModal] unexpected gateway: ${schedule.gateway} for schedule ${schedule.id}`);
|
2021-06-04 18:26:20 +02:00
|
|
|
return <div />;
|
|
|
|
}
|
2021-07-01 12:34:10 +02:00
|
|
|
};
|
2021-06-04 18:26:20 +02:00
|
|
|
|
|
|
|
export const UpdateCardModal: React.FC<UpdateCardModalProps> = ({ isOpen, toggleModal, afterSuccess, onError, operator, schedule }) => {
|
|
|
|
return (
|
|
|
|
<Loader>
|
|
|
|
<UpdateCardModalComponent isOpen={isOpen} toggleModal={toggleModal} afterSuccess={afterSuccess} onError={onError} operator={operator} schedule={schedule} />
|
|
|
|
</Loader>
|
|
|
|
);
|
2021-07-01 12:34:10 +02:00
|
|
|
};
|