diff --git a/public/js/clients/payments/forte-ach-payment.js b/public/js/clients/payments/forte-ach-payment.js
new file mode 100644
index 000000000000..837aeac0b641
--- /dev/null
+++ b/public/js/clients/payments/forte-ach-payment.js
@@ -0,0 +1,81 @@
+/******/ (() => { // webpackBootstrap
+var __webpack_exports__ = {};
+/*!************************************************************!*\
+ !*** ./resources/js/clients/payments/forte-ach-payment.js ***!
+ \************************************************************/
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
+
+/**
+ * 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
+ */
+var ForteAuthorizeACH = function ForteAuthorizeACH(apiLoginId) {
+ var _this = this;
+
+ _classCallCheck(this, ForteAuthorizeACH);
+
+ _defineProperty(this, "handleAuthorization", function () {
+ var account_number = document.getElementById('account-number').value;
+ var routing_number = document.getElementById('routing-number').value;
+ var data = {
+ api_login_id: _this.apiLoginId,
+ account_number: account_number,
+ routing_number: routing_number,
+ account_type: 'checking'
+ };
+ var payNowButton = document.getElementById('pay-now');
+
+ if (payNowButton) {
+ document.getElementById('pay-now').disabled = true;
+ document.querySelector('#pay-now > svg').classList.remove('hidden');
+ document.querySelector('#pay-now > span').classList.add('hidden');
+ } // console.log(data);
+
+
+ forte.createToken(data).success(_this.successResponseHandler).error(_this.failedResponseHandler);
+ return false;
+ });
+
+ _defineProperty(this, "successResponseHandler", function (response) {
+ document.getElementById('payment_token').value = response.onetime_token;
+ document.getElementById('server_response').submit();
+ return false;
+ });
+
+ _defineProperty(this, "failedResponseHandler", function (response) {
+ var errors = '
- ' + response.response_description + '
';
+ document.getElementById('forte_errors').innerHTML = errors;
+ document.getElementById('pay-now').disabled = false;
+ document.querySelector('#pay-now > svg').classList.add('hidden');
+ document.querySelector('#pay-now > span').classList.remove('hidden');
+ return false;
+ });
+
+ _defineProperty(this, "handle", function () {
+ var payNowButton = document.getElementById('pay-now');
+
+ if (payNowButton) {
+ payNowButton.addEventListener('click', function (e) {
+ _this.handleAuthorization();
+ });
+ }
+
+ return _this;
+ });
+
+ this.apiLoginId = apiLoginId;
+};
+
+var apiLoginId = document.querySelector('meta[name="forte-api-login-id"]').content;
+/** @handle */
+
+new ForteAuthorizeACH(apiLoginId).handle();
+/******/ })()
+;
\ No newline at end of file
diff --git a/public/js/clients/payments/forte-credit-card-payment.js b/public/js/clients/payments/forte-credit-card-payment.js
new file mode 100644
index 000000000000..2c181f59171d
--- /dev/null
+++ b/public/js/clients/payments/forte-credit-card-payment.js
@@ -0,0 +1,82 @@
+/******/ (() => { // webpackBootstrap
+var __webpack_exports__ = {};
+/*!********************************************************************!*\
+ !*** ./resources/js/clients/payments/forte-credit-card-payment.js ***!
+ \********************************************************************/
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
+
+/**
+ * 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
+ */
+var ForteAuthorizeCard = function ForteAuthorizeCard(apiLoginId) {
+ var _this = this;
+
+ _classCallCheck(this, ForteAuthorizeCard);
+
+ _defineProperty(this, "handleAuthorization", function () {
+ var myCard = $('#my-card');
+ var data = {
+ api_login_id: _this.apiLoginId,
+ card_number: myCard.CardJs('cardNumber').replace(/[^\d]/g, ''),
+ expire_year: myCard.CardJs('expiryYear').replace(/[^\d]/g, ''),
+ expire_month: myCard.CardJs('expiryMonth').replace(/[^\d]/g, ''),
+ cvv: document.getElementById('cvv').value.replace(/[^\d]/g, '')
+ };
+ var payNowButton = document.getElementById('pay-now');
+
+ if (payNowButton) {
+ document.getElementById('pay-now').disabled = true;
+ document.querySelector('#pay-now > svg').classList.remove('hidden');
+ document.querySelector('#pay-now > span').classList.add('hidden');
+ }
+
+ forte.createToken(data).success(_this.successResponseHandler).error(_this.failedResponseHandler);
+ return false;
+ });
+
+ _defineProperty(this, "successResponseHandler", function (response) {
+ document.getElementById('payment_token').value = response.onetime_token;
+ document.getElementById('card_brand').value = response.card_type;
+ document.getElementById('server_response').submit();
+ return false;
+ });
+
+ _defineProperty(this, "failedResponseHandler", function (response) {
+ var errors = '- ' + response.response_description + '
';
+ document.getElementById('forte_errors').innerHTML = errors;
+ document.getElementById('pay-now').disabled = false;
+ document.querySelector('#pay-now > svg').classList.add('hidden');
+ document.querySelector('#pay-now > span').classList.remove('hidden');
+ return false;
+ });
+
+ _defineProperty(this, "handle", function () {
+ var payNowButton = document.getElementById('pay-now');
+
+ if (payNowButton) {
+ payNowButton.addEventListener('click', function (e) {
+ _this.handleAuthorization();
+ });
+ }
+
+ return _this;
+ });
+
+ this.apiLoginId = apiLoginId;
+ this.cardHolderName = document.getElementById('cardholder_name');
+};
+
+var apiLoginId = document.querySelector('meta[name="forte-api-login-id"]').content;
+/** @handle */
+
+new ForteAuthorizeCard(apiLoginId).handle();
+/******/ })()
+;
\ No newline at end of file