617 lines
		
	
	
		
			29 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			617 lines
		
	
	
		
			29 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <!DOCTYPE html>
 | |
| 
 | |
| <html lang="fr" data-kantu="1">
 | |
| <head>
 | |
|     <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 | |
| 
 | |
|     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | |
|     <title>Effectuer un paiement - {{__('providers.'.$method)}}</title>
 | |
|     <meta name="theme-color" content="#000000">
 | |
|     <meta name="csrf-token" content="">
 | |
|     <link rel="icon"  href="{{asset('assets/images/favicon.ico')}}">
 | |
|     <meta name="msapplication-TileColor" content="#ffffff">
 | |
|     <meta name="theme-color" content="#ffffff">
 | |
|     <link rel="stylesheet" href="{{asset('assets/app.css')}}">
 | |
| 
 | |
|     <style>
 | |
|         .option-content1::after {
 | |
|             left: 42%;
 | |
|         }
 | |
|     </style>
 | |
|     <style type="text/css">
 | |
|         #page {
 | |
|             display: none;
 | |
|         }
 | |
| 
 | |
|         #loading {
 | |
|             display: block;
 | |
|             position: absolute;
 | |
|             z-index: 100;
 | |
|             background-position: center;
 | |
|             left: 50%;
 | |
|             top: 50%;
 | |
|             transform: translate(-50%, -50%)
 | |
|         }
 | |
| 
 | |
|         @keyframes  ldio-5owbnf6l9j7 {
 | |
|             0% {
 | |
|                 transform: translate(12px, 80px) scale(0);
 | |
|             }
 | |
|             25% {
 | |
|                 transform: translate(12px, 80px) scale(0);
 | |
|             }
 | |
|             50% {
 | |
|                 transform: translate(12px, 80px) scale(1);
 | |
|             }
 | |
|             75% {
 | |
|                 transform: translate(80px, 80px) scale(1);
 | |
|             }
 | |
|             100% {
 | |
|                 transform: translate(148px, 80px) scale(1);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         @keyframes  ldio-5owbnf6l9j7-r {
 | |
|             0% {
 | |
|                 transform: translate(148px, 80px) scale(1):
 | |
|             }
 | |
|             100% {
 | |
|                 transform: translate(148px, 80px) scale(0);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         @keyframes  ldio-5owbnf6l9j7-c {
 | |
|             0% {
 | |
|                 background: var(--loader-color1)
 | |
|             }
 | |
|             25% {
 | |
|                 background: var(--loader-color2)
 | |
|             }
 | |
|             50% {
 | |
|                 background: var(--loader-color1)
 | |
|             }
 | |
|             75% {
 | |
|                 background: var(--loader-color2)
 | |
|             }
 | |
|             100% {
 | |
|                 background: var(--loader-color1)
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 div {
 | |
|             position: absolute;
 | |
|             width: 40px;
 | |
|             height: 40px;
 | |
|             border-radius: 50%;
 | |
|             transform: translate(80px, 80px) scale(1);
 | |
|             background: var(--loader-color1);
 | |
|             animation: ldio-5owbnf6l9j7 1.2048192771084336s infinite cubic-bezier(0, 0.5, 0.5, 1);
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 div:nth-child(1) {
 | |
|             background: var(--loader-color2);
 | |
|             transform: translate(148px, 80px) scale(1);
 | |
|             animation: ldio-5owbnf6l9j7-r 0.3012048192771084s infinite cubic-bezier(0, 0.5, 0.5, 1), ldio-5owbnf6l9j7-c 1.2048192771084336s infinite step-start;
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 div:nth-child(2) {
 | |
|             animation-delay: -0.3012048192771084s;
 | |
|             background: var(--loader-color1);
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 div:nth-child(3) {
 | |
|             animation-delay: -0.6024096385542168s;
 | |
|             background: var(--loader-color2);
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 div:nth-child(4) {
 | |
|             animation-delay: -0.9036144578313252s;
 | |
|             background: var(--loader-color1);
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 div:nth-child(5) {
 | |
|             animation-delay: -1.2048192771084336s;
 | |
|             background: var(--loader-color2);
 | |
|         }
 | |
| 
 | |
|         .loadingio-spinner-ellipsis-99po1h19hjs {
 | |
|             width: 200px;
 | |
|             height: 200px;
 | |
|             display: inline-block;
 | |
|             overflow: hidden;
 | |
|             background: none;
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 {
 | |
|             width: 100%;
 | |
|             height: 100%;
 | |
|             position: relative;
 | |
|             transform: translateZ(0) scale(1);
 | |
|             backface-visibility: hidden;
 | |
|             transform-origin: 0 0; /* see note above */
 | |
|         }
 | |
| 
 | |
|         .ldio-5owbnf6l9j7 div {
 | |
|             box-sizing: content-box;
 | |
|         }
 | |
| 
 | |
| 
 | |
|         .toggle-content {
 | |
|             display: none;
 | |
|             height: 0;
 | |
|             opacity: 0;
 | |
|             overflow: hidden;
 | |
|             transition: height 350ms ease-in-out, opacity 750ms ease-in-out;
 | |
|         }
 | |
| 
 | |
|         .toggle-content.is-visible {
 | |
|             display: block;
 | |
|             height: auto;
 | |
|             opacity: 1;
 | |
|         }
 | |
|     </style>
 | |
| </head>
 | |
| <body id="body">
 | |
|     <div id="loading">
 | |
|         <div class="loadingio-spinner-ellipsis-99po1h19hjs">
 | |
|             <div class="ldio-5owbnf6l9j7">
 | |
|                 <div></div>
 | |
|                 <div></div>
 | |
|                 <div></div>
 | |
|                 <div></div>
 | |
|                 <div></div>
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
| 
 | |
|     <div id="page" class="container">
 | |
|         <div class="row h-100 justify-content-center">
 | |
|             <div class="col-md-8 col-lg-6 my-auto">
 | |
|                 <div class="desk bg-white shadow-sm">
 | |
|                     <div class="desk-head">
 | |
|                         <div class="row">
 | |
|                             <div class="col-12">
 | |
|                                 <div class="">
 | |
|                                     <div class="media align-items-center">
 | |
|                                         <div class="media-head">
 | |
|                                             <img src="{{$receiver_logo}}" class="rounded media-body mr-2 marchand-logo" alt="{{$receiver}}">
 | |
|                                         </div>
 | |
|                                         <div class="media-body">
 | |
|                                             <p class="marchand-name p-0 m-0">{{$receiver}}</p>
 | |
|                                             <h4 class="due-amount p-0 m-0">{{$amount}}</h4>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                         </div>
 | |
|                     </div>
 | |
|                     <hr class="ml-2 mr-2">
 | |
|                     <div class="desk-body">
 | |
|                         <form id="payment_form" name="begin_form" method="POST" action="{{route('yoomee.v2.checkoutPay')}}">
 | |
|                             <input type="hidden" name="_token" value="{{ app('request')->session()->get('_token') }}">
 | |
|                             <input type="hidden" name="payment_token" value="{{ $payment_token }}">
 | |
|                             <div class="desk-content">
 | |
|                                 <p class="text-center">Payer avec</p>
 | |
|                                 <div class="choose-payment-type">
 | |
|                                     <ul class="nav nav-tabs" id="myTab" role="tablist">
 | |
|                                         <li class="nav-item">
 | |
|                                             <svg xmlns="http://www.w3.org/2000/svg" width="60px" height="60px" viewBox="0 0 100 100">
 | |
|                                                 <g transform="translate(-2978 2535)">
 | |
|                                                     <rect width="100" height="100" transform="translate(2978 -2535)" fill="var()" opacity="0.003"></rect>
 | |
|                                                     <g transform="translate(2403.753 -3004.222)">
 | |
|                                                         <path d="M65.889,1.928H12.373A5.964,5.964,0,0,0,6.427,7.874V91.122a5.964,5.964,0,0,0,5.946,5.946H65.889a5.964,5.964,0,0,0,5.946-5.946V7.874A5.964,5.964,0,0,0,65.889,1.928ZM39.131,92.774a4.625,4.625,0,1,1,4.625-4.625A4.625,4.625,0,0,1,39.131,92.774ZM65.889,79.23H12.373V13.821H65.889Z" transform="translate(584.82 469.294)" fill="var(--cinetpay1)"></path>
 | |
|                                                         <path d="M21.585,0V3.6H0V7.2H21.585v3.6l7.2-5.4ZM7.2,14.39,0,19.787l7.2,5.4v-3.6H28.78v-3.6H7.2Z" transform="translate(609.43 500.731)" fill=" var(--cinetpay1)"></path>
 | |
|                                                     </g>
 | |
|                                                 </g>
 | |
|                                             </svg>
 | |
|                                             <p class="descrip" style="font-size:medium; margin-top: 5px">{{__('providers.'.$method)}}</p>
 | |
|                                         </li>
 | |
|                                     </ul>
 | |
|                                     <div class="tab-content" id="myTabContent">
 | |
|                                         <div class="tab-pane fade active show" id="mobile-money" role="tabpanel" aria-labelledby="mobile-money-tab">
 | |
|                                             <div class="option-content1">
 | |
|                                                 <div class="p-1">
 | |
|                                                     <div class="desk-form">
 | |
|                                                         <div class="phone-input form-group">
 | |
|                                                             <label class="input-title input-phone" for="phone_number">
 | |
|                                                                 Numéro de téléphone
 | |
|                                                             </label>
 | |
|                                                             <div class="iti iti--allow-dropdown iti--separate-dial-code">
 | |
|                                                                 <div class="iti__flag-container">
 | |
|                                                                     <div class="iti__selected-flag" role="combobox"
 | |
|                                                                          aria-controls="iti-0__country-listbox"
 | |
|                                                                          aria-owns="iti-0__country-listbox"
 | |
|                                                                          aria-expanded="false" tabindex="0"
 | |
|                                                                          title="Cameroon (Cameroun): +237"
 | |
|                                                                          aria-activedescendant="iti-0__item-cm">
 | |
|                                                                         <div class="iti__flag iti__cm"></div>
 | |
|                                                                         <div class="iti__selected-dial-code">+237</div>
 | |
|                                                                         <div class="iti__arrow"></div>
 | |
|                                                                     </div>
 | |
|                                                                     <ul class="iti__country-list iti__hide"
 | |
|                                                                         id="iti-0__country-listbox" role="listbox"
 | |
|                                                                         aria-label="List of countries">
 | |
|                                                                         <li class="iti__country iti__standard iti__active"
 | |
|                                                                             tabindex="-1" id="iti-0__item-cm" role="option"
 | |
|                                                                             data-dial-code="237" data-country-code="cm"
 | |
|                                                                             aria-selected="true">
 | |
|                                                                             <div class="iti__flag-box">
 | |
|                                                                                 <div class="iti__flag iti__cm"></div>
 | |
|                                                                             </div>
 | |
|                                                                             <span class="iti__country-name">Cameroon (Cameroun)</span><span
 | |
|                                                                                 class="iti__dial-code">+237</span></li>
 | |
|                                                                     </ul>
 | |
|                                                                 </div>
 | |
|                                                                 <input type="tel" id="phone_number" name="phone_number"
 | |
|                                                                        class="form-control input-tel" value="" autofocus
 | |
|                                                                        required autocomplete="off"
 | |
|                                                                        data-intl-tel-input-id="0"
 | |
|                                                                        style="padding-left: 94px;" minlength="9" maxlength="9"
 | |
|                                                                        placeholder="6 71 23 45 67">
 | |
|                                                             </div>
 | |
|                                                             <img id="payment-method-icon" width="2rem"
 | |
|                                                                  alt="payment method logo"
 | |
|                                                                  src="{{url('assets/images/default.png')}}">
 | |
|                                                             <div>
 | |
|                                                             </div>
 | |
|                                                         </div>
 | |
|                                                         <div>
 | |
|                                                             <div class="col-12 px-0">
 | |
|                                                                 <div>
 | |
|                                                                     <p id="methodscm" class="payment-method-box operator-box">
 | |
|                                                                         @if(str_contains(strtolower($method),'orange'))
 | |
|                                                                             <img
 | |
|                                                                                 src="{{url('assets/images/orange.png')}}"
 | |
|                                                                                 class="rounded mx-1 payment-method-logo"
 | |
|                                                                                 alt="ORANGE">
 | |
|                                                                         @elseif(str_contains(strtolower($method),'mtn'))
 | |
|                                                                             <img
 | |
|                                                                                 src="{{url('assets/images/mtn.png')}}"
 | |
|                                                                                 class="rounded mx-1 payment-method-logo"
 | |
|                                                                                 alt="MTN">
 | |
|                                                                         @elseif(str_contains(strtolower($method),'yoomee'))
 | |
|                                                                             <img
 | |
|                                                                                 src="{{url('assets/images/yoomee.png')}}"
 | |
|                                                                                 class="rounded mx-1 payment-method-logo"
 | |
|                                                                                 alt="yoomee">
 | |
|                                                                         @elseif(str_contains(strtolower($method),'express'))
 | |
|                                                                             <img
 | |
|                                                                                 src="{{url('assets/images/express-union.png')}}"
 | |
|                                                                                 class="rounded mx-1 payment-method-logo"
 | |
|                                                                                 alt="express">
 | |
|                                                                         @else
 | |
|                                                                             <img
 | |
|                                                                                 src="{{url('assets/images/default.png')}}"
 | |
|                                                                                 class="rounded mx-1 payment-method-logo"
 | |
|                                                                                 alt="default">
 | |
|                                                                         @endif
 | |
|                                                                     </p>
 | |
|                                                                 </div>
 | |
|                                                             </div>
 | |
|                                                         </div>
 | |
|                                                     </div>
 | |
|                                                 </div>
 | |
|                                             </div>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                             <div class="desk-action p-3" id="desk-action">
 | |
|                                 <button type="submit" class="btn btn-next btn-block" id="del">
 | |
|                                     Payer {{$amount}}
 | |
|                                 </button>
 | |
|                             </div>
 | |
|                         </form>
 | |
|                     </div>
 | |
|                 </div>
 | |
|                 @include('footer')
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
|     <script src="{{asset('assets/sweetalert2/sweetalert2.all.min.js')}}"></script>
 | |
|     <script src="{{asset('assets/app.js')}}"></script>
 | |
|     <script>
 | |
| 
 | |
|         document.addEventListener('readystatechange', function (event) {
 | |
|             if (event.target.readyState === 'complete') {
 | |
|                 ready();
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         function ready() {
 | |
|             setTimeout(function () {
 | |
|                 fadeIn(document.getElementById('page'))
 | |
|             }, 217)
 | |
|             fadeOut(document.getElementById('loading'));
 | |
|         }
 | |
| 
 | |
|         // ** FADE OUT FUNCTION **
 | |
|         function fadeOut(el) {
 | |
|             el.style.opacity = 1;
 | |
|             (function fade() {
 | |
|                 if ((el.style.opacity -= .1) < 0) {
 | |
|                     el.style.display = "none";
 | |
|                 } else {
 | |
|                     requestAnimationFrame(fade);
 | |
|                 }
 | |
|             })();
 | |
|         }
 | |
| 
 | |
|         // ** FADE IN FUNCTION **
 | |
|         function fadeIn(el, display) {
 | |
|             el.style.opacity = 0;
 | |
|             el.style.display = display || "block";
 | |
|             (function fade() {
 | |
|                 var val = parseFloat(el.style.opacity);
 | |
|                 if (!((val += .1) > 1)) {
 | |
|                     el.style.opacity = val;
 | |
|                     requestAnimationFrame(fade);
 | |
|                 }
 | |
|             })();
 | |
|         }
 | |
| 
 | |
|         function empty(item) {
 | |
|             return (item === undefined || item === null || item === false || item === '');
 | |
|         }
 | |
|     </script>
 | |
| 
 | |
|     <script>
 | |
|         document.addEventListener('readystatechange', function (event) {
 | |
|             if (event.target.readyState === 'complete') {
 | |
|                 disableButtonOnSubmit();
 | |
|             }
 | |
|         });
 | |
|         function disableButtonOnSubmit() {
 | |
|             var form = document.getElementById('payment_form');
 | |
|             var submitButton = document.getElementById('del');
 | |
|             form.addEventListener('submit', function () {
 | |
|                 submitButton.disabled = true;
 | |
|                 setTimeout(function () {
 | |
|                     submitButton.disabled = false;
 | |
|                 }, 15000)
 | |
|             })
 | |
|         }
 | |
|     </script>
 | |
|     <script>
 | |
| 
 | |
|         @if(session('error'))
 | |
|             Swal.fire({
 | |
|                 title: 'Error!',
 | |
|                 text: "{{session('error')}}",
 | |
|                 icon: 'error',
 | |
|                 confirmButtonText: 'OK'
 | |
|             })
 | |
|         @endif
 | |
| 
 | |
|         function initializeIntelInput() {
 | |
|             try {
 | |
|                 if (empty(window.intlTelInput) && intlTelInput) {
 | |
|                     window.intlTelInput = intlTelInput;
 | |
|                 }
 | |
| 
 | |
|                 var phoneNumberInput = document.querySelector("#phone_number");
 | |
| 
 | |
|                 var iti = window.intlTelInput(phoneNumberInput, {
 | |
|                     hiddenInput: "phone_number",
 | |
|                     onlyCountries: ["cm"],
 | |
|                     placeholderNumberType: "MOBILE",
 | |
|                     initialCountry: 'cm',
 | |
|                     localizedCountries: {"cd": "Congo RDC"},
 | |
|                     separateDialCode: true,
 | |
|                     utilsScript: "/assets/utils.js",
 | |
|                     customPlaceholder: function (selectedCountryPlaceholder, selectedCountryData) {
 | |
|                         if (selectedCountryData.iso2 === 'ci') {
 | |
|                             return '01 23 45 67 89';
 | |
|                         } else {
 | |
|                             return selectedCountryPlaceholder;
 | |
|                         }
 | |
|                     },
 | |
|                 });
 | |
| 
 | |
|                 var countryJsData = iti.getSelectedCountryData();
 | |
|                 var countryJs = 'cm';
 | |
|                 if (!empty(countryJsData) && !empty(countryJsData.iso2)) {
 | |
|                     countryJs = countryJsData.iso2;
 | |
|                     getMobileMoneyPaymentMethodLogo(iti);
 | |
|                 }
 | |
| 
 | |
|                 var methodCountry = document.getElementById("methods" + countryJs);
 | |
|                 showCurrentLogos(methodCountry);
 | |
| 
 | |
|                 phoneNumberInput.addEventListener('countrychange', function (e) {
 | |
|                     const methodCountry = document.getElementById("methods" + iti.getSelectedCountryData().iso2)
 | |
|                     showCurrentLogos(methodCountry);
 | |
|                     getMobileMoneyPaymentMethodLogo(iti);
 | |
|                 });
 | |
| 
 | |
| 
 | |
|                 phoneNumberInput.addEventListener('paste', function (e) {
 | |
|                     getMobileMoneyPaymentMethodLogo(iti);
 | |
|                 });
 | |
|                 phoneNumberInput.addEventListener('keyup', function (e) {
 | |
|                     getMobileMoneyPaymentMethodLogo(iti);
 | |
|                 });
 | |
| 
 | |
|                 if (!empty(phoneNumberInput)) {
 | |
|                     setInputFilter(phoneNumberInput, function (value) {
 | |
|                         return /^\d*\.?\d*$/.test(value.replace(/\s/g, ''));
 | |
|                     });
 | |
|                 }
 | |
| 
 | |
| 
 | |
|                 var countryData = iti.getSelectedCountryData()
 | |
|                 var countryIso = countryData.iso2;
 | |
|                 var phoneNumber = phoneNumberInput.value.replace("+" + iti.dialCode, "").trim();
 | |
|                 displayPaymentMethodLogo(countryIso, phoneNumber);
 | |
|                 return true;
 | |
|             } catch (e) {
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         function getMobileMoneyPaymentMethodLogo(itiEvent) {
 | |
|             var countryData = itiEvent.getSelectedCountryData()
 | |
|             var countryIso = countryData.iso2;
 | |
|             var phoneNumber = itiEvent.getNumber().replace("+" + countryData.dialCode, "").trim();
 | |
|             return displayPaymentMethodLogo(countryIso, phoneNumber);
 | |
|         }
 | |
| 
 | |
|         if (document.readyState !== 'loading') {
 | |
|             initializeIntelInput();
 | |
| 
 | |
|         } else {
 | |
|             document.addEventListener("DOMContentLoaded", initializeIntelInput);
 | |
|         }
 | |
| 
 | |
|     </script>
 | |
|     <script>
 | |
|         if (!String.prototype.startsWith) {
 | |
|             Object.defineProperty(String.prototype, 'startsWith', {
 | |
|                 value: function (search, rawPos) {
 | |
|                     var pos = rawPos > 0 ? rawPos | 0 : 0;
 | |
|                     return this.substring(pos, pos + search.length) === search;
 | |
|                 }
 | |
|             });
 | |
|         }
 | |
| 
 | |
|         var paymentMethods = {
 | |
|             "bf": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{
 | |
|                     "values": ["55", "64", "65", "66", "67", "74", "75", "76", "77"],
 | |
|                     "name": "orange"
 | |
|                 }, {"values": ["51", "53", "60", "61", "62", "63", "70", "71", "72", "73"], "name": "moov"}],
 | |
|                 "max_digits": 8,
 | |
|                 "currencies": ["XOF"]
 | |
|             },
 | |
|             "bj": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{
 | |
|                     "values": ["51", "52", "53", "54", "61", "62", "66", "67", "69", "90", "91", "96", "97"],
 | |
|                     "name": "mtn"
 | |
|                 }, {"values": ["60", "63", "64", "65", "94", "95", "98", "99"], "name": "moov"}],
 | |
|                 "max_digits": 8,
 | |
|                 "currencies": ["XOF"]
 | |
|             },
 | |
|             "cd": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{
 | |
|                     "values": ["80", "84", "85", "89"],
 | |
|                     "currencies": ["CDF", "USD"],
 | |
|                     "name": "orange"
 | |
|                 }, {
 | |
|                     "currencies": ["CDF", "USD"],
 | |
|                     "values": ["97", "99"],
 | |
|                     "name": "airtel"
 | |
|                 }, {
 | |
|                     "values": ["81", "82", "83", "081", "082", "080", "083"],
 | |
|                     "currencies": ["CDF", "USD"],
 | |
|                     "name": "mpesa"
 | |
|                 }],
 | |
|                 "max_digits": 10,
 | |
|                 "currencies": ["CDF", "USD"]
 | |
|             },
 | |
|             "ci": {
 | |
|                 "regex": [{
 | |
|                     "values": "^[0,4,5,6,7,8,9]{1}[7,8,9]\\d{0,8}",
 | |
|                     "name": "orange"
 | |
|                 }, {
 | |
|                     "values": "^[0,4,5,6,7,8,9]{1}[4,5,6]\\d{0,8}",
 | |
|                     "name": "mtn"
 | |
|                 }, {"values": "^[0,4,5,6,7,8,9]{1}[0,1,2,3]{1}\\d{0,8}", "name": "moov"}],
 | |
|                 "prefixes": [],
 | |
|                 "max_digits": 10,
 | |
|                 "currencies": ["XOF"]
 | |
|             },
 | |
|             "cm": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [
 | |
|                     {
 | |
|                         "values": ["690", "691", "692", "693", "694", "695", "696", "697", "698", "699", "655", "656", "657", "658", "659"],
 | |
|                         "name": "orange"
 | |
|                     },
 | |
|                     {
 | |
|                         "values": ["680", "681", "682", "683", "684", "685", "686", "687", "688", "689", "650", "651", "652", "653", "654", "678"],
 | |
|                         "name": "mtn"
 | |
|                     },
 | |
|                     {
 | |
|                         "values": ["230", "231", "232" , "233" , "240","241","242"],
 | |
|                         "name": "yoomee"
 | |
|                     }
 | |
|                 ],
 | |
|                 "max_digits": 10,
 | |
|                 "currencies": ["XAF"]
 | |
|             },
 | |
|             "ml": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{"values": ["65", "66", "67", "68", "69", "95", "96", "97", "98", "99"], "name": "moov"}],
 | |
|                 "max_digits": 10,
 | |
|                 "currencies": ["XOF"]
 | |
|             },
 | |
|             "ne": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{"values": ["86", "87", "88", "89", "96", "97", "98", "99"], "name": "airtel"}],
 | |
|                 "max_digits": 8,
 | |
|                 "currencies": ["XOF"]
 | |
|             },
 | |
|             "sn": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{"values": ["77", "78"], "name": "orange"}, {
 | |
|                     "values": ["65", "66", "76"],
 | |
|                     "name": "freemoney"
 | |
|                 }, {"values": ["70"], "name": "expresso"}],
 | |
|                 "max_digits": 10,
 | |
|                 "currencies": ["XOF"]
 | |
|             },
 | |
|             "tg": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{
 | |
|                     "values": ["79", "96", "97", "98", "99"],
 | |
|                     "name": "moov"
 | |
|                 }, {"values": ["70", "90", "91", "92", "93"], "name": "tmoney"}],
 | |
|                 "max_digits": 10,
 | |
|                 "currencies": ["XOF"]
 | |
|             },
 | |
|             "gn": {
 | |
|                 "regex": [],
 | |
|                 "prefixes": [{"values": ["610", "611", "62"], "name": "orange"}, {"values": ["66"], "name": "mtn"}],
 | |
|                 "max_digits": 8,
 | |
|                 "currencies": ["GNF"]
 | |
|             }
 | |
|         };
 | |
| 
 | |
|         function displayPaymentMethodLogo(country, phoneNumber) {
 | |
|             var countriesPaymentMethods = paymentMethods[country.toLowerCase()];
 | |
|             var logosPath = '/assets/images/';
 | |
|             var logo = 'default';
 | |
|             if (countriesPaymentMethods !== undefined) {
 | |
|                 var countriesPaymentMethodsRegexEntries = countriesPaymentMethods['regex'];
 | |
|                 var countriesPaymentMethodsValuesEntries = countriesPaymentMethods['prefixes'];
 | |
|                 if (typeof countriesPaymentMethodsRegexEntries !== undefined && countriesPaymentMethodsRegexEntries.length > 0) {
 | |
|                     for (var regexItem of countriesPaymentMethodsRegexEntries) {
 | |
|                         if (new RegExp(regexItem.values).test(phoneNumber) && phoneNumber.length <= countriesPaymentMethods['max_digits']) {
 | |
|                             logo = regexItem.name;
 | |
|                             document.getElementById("payment-method-icon").src = logosPath + logo + '.png';
 | |
|                             return;
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|                 if (typeof countriesPaymentMethodsValuesEntries !== undefined && countriesPaymentMethodsValuesEntries.length > 0) {
 | |
|                     for (var prefixItem of countriesPaymentMethodsValuesEntries) {
 | |
|                         var prefixes = prefixItem['values'];
 | |
|                         for (var prefix of prefixes) {
 | |
|                             if (phoneNumber.startsWith(prefix) && phoneNumber.length <= countriesPaymentMethods['max_digits']) {
 | |
|                                 logo = prefixItem['name'];
 | |
|                                 document.getElementById("payment-method-icon").src = logosPath + logo + '.png';
 | |
|                                 return;
 | |
|                             }
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|             document.getElementById("payment-method-icon").src = logosPath + 'default.png';
 | |
|         }
 | |
|     </script>
 | |
| 
 | |
| </body>
 | |
| </html>
 |