mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-11 13:42:49 +01:00
128 lines
3.9 KiB
JavaScript
Vendored
128 lines
3.9 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://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();
|