mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 22:02:54 -04:00 
			
		
		
		
	- Pass instance of $gateway to authorize page for fields verification - Support for multiple tokens
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
			Vendored
		
	
	
	
| /**
 | |
|  * Invoice Ninja (https://invoiceninja.com)
 | |
|  *
 | |
|  * @link https://github.com/invoiceninja/invoiceninja source repository
 | |
|  *
 | |
|  * @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
 | |
|  *
 | |
|  * @license https://opensource.org/licenses/AAL
 | |
|  */
 | |
| 
 | |
| class AuthorizeACH {
 | |
|     constructor() {
 | |
|         this.errors = document.getElementById('errors');
 | |
|         this.key = document.querySelector(
 | |
|             'meta[name="stripe-publishable-key"]'
 | |
|         ).content;
 | |
|     }
 | |
| 
 | |
|     setupStripe = () => {
 | |
|         this.stripe = Stripe(this.key);
 | |
| 
 | |
|         return this;
 | |
|     };
 | |
| 
 | |
|     getFormData = () => {
 | |
|         return {
 | |
|             country: document.getElementById('country').value,
 | |
|             currency: document.getElementById('currency').value,
 | |
|             routing_number: document.getElementById('routing-number').value,
 | |
|             account_number: document.getElementById('account-number').value,
 | |
|             account_holder_name: document.getElementById('account-holder-name')
 | |
|                 .value,
 | |
|             account_holder_type: document.querySelector(
 | |
|                 'input[name="account-holder-type"]:checked'
 | |
|             ).value,
 | |
|         };
 | |
|     };
 | |
| 
 | |
|     handleError = (message) => {
 | |
|         document.getElementById('save-button').disabled = false;
 | |
|         document.querySelector('#save-button > svg').classList.add('hidden');
 | |
|         document.querySelector('#save-button > span').classList.remove('hidden');
 | |
| 
 | |
|         this.errors.textContent = '';
 | |
|         this.errors.textContent = message;
 | |
|         this.errors.hidden = false;
 | |
|     };
 | |
| 
 | |
|     handleSuccess = (response) => {
 | |
|         document.getElementById('gateway_response').value = JSON.stringify(
 | |
|             response
 | |
|         );
 | |
| 
 | |
|         document.getElementById('server_response').submit();
 | |
|     };
 | |
| 
 | |
|     handleSubmit = (e) => {
 | |
|         document.getElementById('save-button').disabled = true;
 | |
|         document.querySelector('#save-button > svg').classList.remove('hidden');
 | |
|         document.querySelector('#save-button > span').classList.add('hidden');
 | |
| 
 | |
|         e.preventDefault();
 | |
| 
 | |
|         this.errors.textContent = '';
 | |
|         this.errors.hidden = true;
 | |
| 
 | |
|         this.stripe
 | |
|             .createToken('bank_account', this.getFormData())
 | |
|             .then((result) => {
 | |
|                 if (result.hasOwnProperty('error')) {
 | |
|                     return this.handleError(result.error.message);
 | |
|                 }
 | |
| 
 | |
|                 return this.handleSuccess(result);
 | |
|             });
 | |
|     };
 | |
| 
 | |
|     handle() {
 | |
|         document
 | |
|             .getElementById('save-button')
 | |
|             .addEventListener('click', (e) => this.handleSubmit(e));
 | |
|     }
 | |
| }
 | |
| 
 | |
| new AuthorizeACH().setupStripe().handle();
 |