/** * 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://www.elastic.co/licensing/elastic-license */ class Payment { constructor(displayTerms, displaySignature) { this.shouldDisplayTerms = displayTerms; this.shouldDisplaySignature = displaySignature; this.termsAccepted = false; this.submitting = false; } handleMethodSelect(element) { document.getElementById("company_gateway_id").value = element.dataset.companyGatewayId; document.getElementById("payment_method_id").value = element.dataset.gatewayTypeId; if (this.shouldDisplaySignature && !this.shouldDisplayTerms) { if(this.signaturePad && this.signaturePad.isEmpty()) alert("Please sign"); this.displayTerms(); document .getElementById("accept-terms-button") .addEventListener("click", () => { this.termsAccepted = true; this.submitForm(); }); } if (!this.shouldDisplaySignature && this.shouldDisplayTerms) { this.displaySignature(); document .getElementById("signature-next-step") .addEventListener("click", () => { document.querySelector('input[name="signature"').value = this.signaturePad.toDataURL(); this.submitForm(); }); } if (this.shouldDisplaySignature && this.shouldDisplayTerms) { this.displaySignature(); document .getElementById("signature-next-step") .addEventListener("click", () => { this.displayTerms(); document .getElementById("accept-terms-button") .addEventListener("click", () => { document.querySelector('input[name="signature"').value = this.signaturePad.toDataURL(); this.termsAccepted = true; this.submitForm(); }); }); } if (!this.shouldDisplaySignature && !this.shouldDisplayTerms) { this.submitForm(); } } submitForm() { this.submitting = true; document.getElementById("payment-form").submit(); } displayTerms() { let displayTermsModal = document.getElementById("displayTermsModal"); displayTermsModal.removeAttribute("style"); } displaySignature() { let displaySignatureModal = document.getElementById( "displaySignatureModal" ); displaySignatureModal.removeAttribute("style"); const signaturePad = new SignaturePad( document.getElementById("signature-pad"), { penColor: "rgb(0, 0, 0)" } ); signaturePad.onEnd = function(){ document.getElementById("signature-next-step").disabled = false; }; this.signaturePad = signaturePad; } handle() { document.getElementById("signature-next-step").disabled = true; document .querySelectorAll(".dropdown-gateway-button") .forEach(element => { element.addEventListener("click", () => { if (!this.submitting) { this.handleMethodSelect(element) } }); }); } } const signature = document.querySelector( 'meta[name="require-invoice-signature"]' ).content; const terms = document.querySelector('meta[name="show-invoice-terms"]').content; new Payment(Boolean(+signature), Boolean(+terms)).handle();