From 18465ee8e9b36462122a5050ef33755fa0db9d9f Mon Sep 17 00:00:00 2001 From: Sylvain Date: Wed, 10 Mar 2021 16:46:18 +0100 Subject: [PATCH] select gateway modal --- .../components/select-gateway-modal.tsx | 41 +++++++++++++++---- .../javascript/controllers/admin/invoices.js | 16 ++++++++ app/frontend/src/stylesheets/application.scss | 1 + .../modules/select-gateway-modal.scss | 25 +++++++++++ .../templates/admin/invoices/payment.html | 1 + config/locales/app.admin.en.yml | 8 ++++ config/locales/app.admin.fr.yml | 8 ++++ 7 files changed, 93 insertions(+), 7 deletions(-) create mode 100644 app/frontend/src/stylesheets/modules/select-gateway-modal.scss diff --git a/app/frontend/src/javascript/components/select-gateway-modal.tsx b/app/frontend/src/javascript/components/select-gateway-modal.tsx index 4de7d3212..7a7f258af 100644 --- a/app/frontend/src/javascript/components/select-gateway-modal.tsx +++ b/app/frontend/src/javascript/components/select-gateway-modal.tsx @@ -2,7 +2,7 @@ * This component ... */ -import React from 'react'; +import React, { BaseSyntheticEvent, SyntheticEvent, useState } from 'react'; import { react2angular } from 'react2angular'; import { Loader } from './loader'; import { IApplication } from '../models/application'; @@ -20,23 +20,50 @@ interface SelectGatewayModalModalProps { } const SelectGatewayModal: React.FC = ({ isOpen, toggleModal }) => { - const { t } = useTranslation('admin'); + const [preventConfirmGateway, setPreventConfirmGateway] = useState(true); + const [selectedGateway, setSelectedGateway] = useState(''); + + + /** + * Callback triggered when the user has filled and confirmed the settings of his gateway + */ + const onGatewayConfirmed = () => { + setPreventConfirmGateway(true); + toggleModal(); + } + + const setGateway = (event: BaseSyntheticEvent) => { + const gateway = event.target.value; + setSelectedGateway(gateway); + setPreventConfirmGateway(!gateway); + } return ( - - + className="gateway-modal" + confirmButton={t('app.admin.invoices.payment.gateway_modal.confirm_button')} + onConfirm={onGatewayConfirmed} + preventConfirm={preventConfirmGateway}> +

+ {t('app.admin.invoices.payment.gateway_modal.gateway_info')} +

+ +
); } -const StripeModalWrapper: React.FC = ({ isOpen, toggleModal,currentUser }) => { +const SelectGatewayModalWrapper: React.FC = ({ isOpen, toggleModal, currentUser }) => { return ( @@ -44,4 +71,4 @@ const StripeModalWrapper: React.FC = ({ isOpen, to ); } -Application.Components.component('stripeModal', react2angular(StripeModalWrapper, ['isOpen', 'toggleModal', 'currentUser'])); +Application.Components.component('selectGatewayModal', react2angular(SelectGatewayModalWrapper, ['isOpen', 'toggleModal', 'currentUser'])); diff --git a/app/frontend/src/javascript/controllers/admin/invoices.js b/app/frontend/src/javascript/controllers/admin/invoices.js index 4a99698b0..77484dec0 100644 --- a/app/frontend/src/javascript/controllers/admin/invoices.js +++ b/app/frontend/src/javascript/controllers/admin/invoices.js @@ -198,6 +198,9 @@ Application.Controllers.controller('InvoicesController', ['$scope', '$state', 'I // Placeholding date for the reservation end $scope.inOneWeekAndOneHour = moment().add(1, 'week').add(1, 'hour').startOf('hour'); + // Is shown the modal dialog to select a payment gateway + $scope.openSelectGatewayModal = false; + /** * Change the invoices ordering criterion to the one provided * @param orderBy {string} ordering criterion @@ -644,6 +647,9 @@ Application.Controllers.controller('InvoicesController', ['$scope', '$state', 'I $scope.selectPaymentGateway = function (onlinePaymentModule) { // if the online payment is about to be disabled, accept the change without any further question if (onlinePaymentModule.value === false) return true; + + // otherwise, open a modal to ask for the selection of a payment gateway + $scope.openSelectGatewayModal = true; }; /** @@ -682,6 +688,16 @@ Application.Controllers.controller('InvoicesController', ['$scope', '$state', 'I return modalInstance.result; }; + /** + * This will open/close the gateway selection modal + */ + $scope.toggleSelectGatewayModal = function () { + setTimeout(() => { + $scope.openSelectGatewayModal = !$scope.openSelectGatewayModal; + $scope.$apply(); + }, 50); + }; + /** * Setup the feature-tour for the admin/invoices page. * This is intended as a contextual help (when pressing F1) diff --git a/app/frontend/src/stylesheets/application.scss b/app/frontend/src/stylesheets/application.scss index fac4aacf6..c78f12976 100644 --- a/app/frontend/src/stylesheets/application.scss +++ b/app/frontend/src/stylesheets/application.scss @@ -32,5 +32,6 @@ @import "modules/payment-schedules-list"; @import "modules/stripe-confirm"; @import "modules/payment-schedule-dashboard"; +@import "modules/select-gateway-modal"; @import "app.responsive"; diff --git a/app/frontend/src/stylesheets/modules/select-gateway-modal.scss b/app/frontend/src/stylesheets/modules/select-gateway-modal.scss new file mode 100644 index 000000000..971a07989 --- /dev/null +++ b/app/frontend/src/stylesheets/modules/select-gateway-modal.scss @@ -0,0 +1,25 @@ +.gateway-modal { + .info-gateway { + border: 1px solid #bce8f1; + border-radius: 4px; + color: #31708f; + background-color: #d9edf7; + padding: 15px; + } + + .select-gateway { + display: block; + width: 100%; + height: 38px; + padding: 6px 12px; + font-size: 16px; + line-height: 1.5; + color: #555555; + background-color: #fff; + background-image: none; + border: 1px solid #c4c4c4; + border-radius: 4px; + box-shadow: inset 0 1px 1px rgba(0, 0, 0, .08); + transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s; + } +} diff --git a/app/frontend/templates/admin/invoices/payment.html b/app/frontend/templates/admin/invoices/payment.html index d5836fa00..07509f76b 100644 --- a/app/frontend/templates/admin/invoices/payment.html +++ b/app/frontend/templates/admin/invoices/payment.html @@ -13,6 +13,7 @@ on-before-save="selectPaymentGateway" fa-icon="fa-font"> +

{{ 'app.admin.invoices.payment.stripe_keys' }}

diff --git a/config/locales/app.admin.en.yml b/config/locales/app.admin.en.yml index 77f427439..972363d40 100644 --- a/config/locales/app.admin.en.yml +++ b/config/locales/app.admin.en.yml @@ -640,6 +640,14 @@ en: currency_info_html: "Please specify below the currency used for online payment. You should provide a three-letter ISO code, from the list of Stripe supported currencies." currency_alert_html: "Warning: the currency cannot be changed after the first online payment was made. Please define this setting carefully before opening Fab-manager to your members." stripe_currency: "Stripe currency" + # select a payment gateway + gateway_modal: + select_gateway_title: "Select a payment gateway" + gateway_info: "To securely collect and process payments online, Fab-manager needs to use an third-party service authorized by the financial institutions, called a payment gateway." + select_gateway: "Please select an available gateway" + stripe: "Stripe" + payzen: "PayZen" + confirm_button: "Validate the gateway" payment_schedules: filter_schedules: "Filter schedules" no_payment_schedules: "No payment schedules to display" diff --git a/config/locales/app.admin.fr.yml b/config/locales/app.admin.fr.yml index 1af569356..2c4cd6b99 100644 --- a/config/locales/app.admin.fr.yml +++ b/config/locales/app.admin.fr.yml @@ -640,6 +640,14 @@ fr: currency_info_html: "Veuillez indiquer la devise à utiliser lors des paiements en ligne. Vous devez fournir un code ISO à trois lettres, issu de la liste des devises supportées par Stripe." currency_alert_html: "Attention : la devise ne peut pas être modifiée après que le premier paiement en ligne ait été effectué. Veuillez définir attentivement ce paramètre avant d'ouvrir Fab-manager à vos membres." stripe_currency: "Devise Stripe" + # select a payment gateway + gateway_modal: + select_gateway_title: "Sélectionnez une passerelle de paiement" + gateway_info: "Pour collecter et traiter les paiements en ligne en toute sécurité, Fab-manager a besoin d'utiliser un service tiers autorisé par les institutions financières, appelé une passerelle de paiement." + select_gateway: "Veuillez choisir une des passerelles disponibles" + stripe: "Stripe" + payzen: "PayZen" + confirm_button: "Valider la passerelle" payment_schedules: filter_schedules: "Filtrer les échéanciers" no_payment_schedules: "Pas d'échéancier à afficher"