Change log

Payment Form Javascript

Options for controlling and further customising payment form submissions are available via javascript events.

Payment Form Events

Payment form events can be intercepted for implementing your own customisations around form validations and submissions.

Ensure you have the most up-to-date reCaptcha v3 script inserted in your form code layout in order to utilise the below event function. Either by restoring your form layout to default or by selecting the reCaptcha v3 code from the “Form Fields” manager above the form layout window.

CMS_CustomSubmit

This event will be triggered after a reCaptcha v3 validation (instead of the regular `submit` event), allowing you to add any additional validation actions (or other custom functions) and stop the regular form submit via event.preventDefault().
This is helpful for performing an AJAX submission of the form (along with already validated reCaptcha token and payment data).

Returned data:

Example from a Stripe transaction.

{
	"form": [form Object],
	"paymentMethod": {
		"id": "pm_1Il7u9433Ww5sV49gBZgIjEO",
		"object": "payment_method",
		"billing_details": {
			"address": {
				"city": null,
				"country": null,
				"line1": null,
				"line2": null,
				"postal_code": null,
				"state": null
			},
			"email": "test@testing.com",
			"name": null,
			"phone": null
		},
		"card": {
			"brand": "visa",
			"checks": {
				"address_line1_check": null,
				"address_postal_code_check": null,
				"cvc_check": null
			},
			"country": "US",
			"exp_month": 4,
			"exp_year": 2024,
			"funding": "credit",
			"generated_from": null,
			"last4": "4242",
			"networks": {
				"available": [
					"visa"
				],
				"preferred": null
			},
			"three_d_secure_usage": {
				"supported": true
			},
			"wallet": null
		},
		"created": 1619595234,
		"customer": null,
		"livemode": false,
		"type": "card"
	}
}
Example usage:
var myForm = document.getElementById("myFormId");

myForm.addEventListener("CMS_CustomSubmit", function(event) {
    var data = event.data;
    console.log("Event data: ", data);
    
    event.preventDefault();

    // perform ajax form submit or other functions here...
});
AJAX Requests & Bambora EU Gateway:

If submitting the form via AJAX, remember to append the &jsonResponse=1 to your form’s action attribute.

However, if using the Bambora EU payment gateway (when payment type is set to Credit Card), the action (or AJAX request path) needs to be set to /bambora/token?form=myFormAlias. Where `myFormAlias` is to be the actual alias of your form.

CMS_triggerHandlePayment

Allows you to continue submitting any payment data after interception by the CMS_CustomSubmit event.

event.data should be taken from CMS_CustomSubmit event.
responseObject is a response data that was returned from a custom AJAX form submit (if such was applicable). If no ajax submit was performed, data will be `null`.
All payments for submits are powered by AJAX validation. Errors will be shown via an alert function.

Send data:
{
    "submitData": event.data,
    "response": responseObject 
}
Example usage:
var myForm = document.getElementById("myFormId");

myForm.addEventListener("CMS_CustomSubmit", function(event) {
    var data = event.data;
    console.log("CMS_CustomSubmit", data);

    event.preventDefault();

    // perform ajax form submit or other functions here...
    
    // send trigger in order to finalize payment
    var trigger = new Event('CMS_triggerHandlePayment');
    trigger.data = {
        "submitData": data,
        "response": response
    };
    data.form.dispatchEvent(trigger);
});

CMS_AfterFormPaymentHandled

Allows you to work with the response from the submitted payment request and add your own customisations before the form redirect is actioned.

Event is triggered once payment was made successfully OR if next step is a redirect to payment provider (BamboraEU (redirect) setup or Paypal Payment_Method) or to 3D Secure page (Stripe).

Returned data:
{
    "FormRedirectLink" : "",
    "LinkType": "3DSecure|SuccessPage|PaymentRedirect",
    "Response": object
}
Example usage:
var myForm = document.getElementById("myFormId");

myForm.addEventListener("CMS_AfterFormPaymentHandled", function(event) {
    console.log("CMS_AfterFormPaymentHandled", event.data);
    // do some stuff here before the FormRedirect

    if (event.data.LinkType == "3DSecure") {
        // for stripe
        var paymentID = extractGetparamFromURL(event.data.FormRedirectLink, "payment_intent");

        // do any stuff before redirect.
        // For example, submit a custom module item, set as disabled, with paymentID assigned.
        // Then on form success page you could update that item which could be found by {{this.order.paymentIntentId}}
        window.location = event.data.FormRedirectLink;
    } else if (event.data.LinkType == "PaymentRedirect") {
        // for paypal flow redirect
        var paymentID = extractGetparamFromURL(event.data.FormRedirectLink, "token");
        // for BamboraEU (Redirect)
        var paymentID = extractGetparamFromURL(event.data.FormRedirectLink, "customOrderId");

        // do any stuff before redirect.
        // For example, submit a custom module item, set as disabled, with paymentID assigned.
        // Then on form success page you could update that item which could be found by {{this.order.paymentIntentId}} (for paypal) or {{request.request_url.params['customOrderId']}} (for for BamboraEU (Redirect))
        window.location = event.data.FormRedirectLink;
    } else {
        // do any stuff before redirect.
        // For example, submit a custom module item, set as enabled.
        window.location = event.data.FormRedirectLink;
    }
});


Related Articles

  • Site Settings & Management
    System Pages

    System Pages, under 'Settings', is where you’ll find all those pages required by certain system...
  • Reports
    Custom Reports

    Custom reports can be used to bring CRM data together, as a spreadsheet, based on your requirements.
  • Liquid Components
    form

    This component outputs data relating to a specific Form. {% component type: "form", alias: "<form_alias>"...
  • CRM
    Form Submissions

    Form Submissions store the captured data from any form submission made on your website (from a form created under ‘Content’ > ‘Forms’).
  • OpenAPI (Admin)
    CRM Cases API

    Create, Retrieve, Update and Delete CRM Cases via the public API endpoint using "where" filtering.
  • Email Notifications
    System Emails

    System emails are emails that are sent when a particular action is carried out on the website and/or via the admin.
  • Liquid Objects & Usage
    {{ formSubmissionData }} object

    This liquid object will output the submission details of a Form.
  • CRM
    Advanced CRM Groups

    Advanced CRM Groups allow you to extend the data fields within multiple areas of the CRM, either globally or on a per-record basis.
  • Liquid Objects & Usage
    {{ workflow }} object

    This liquid object will output the Workflow details of a submitted Form. You can use...
  • Content Modules
    Forms

    Forms are an essential part of collecting user information on your website.
    WebinOne makes managing forms easy and powerful
  • Liquid Objects & Usage
    {{ order }} object

    This liquid object will output the order details of a submitted payment. {{ this.order }}...
  • Content Modules
    Secure Zones

    Secure Zones provide a way of creating restricted content on your website that only registered Secure Zone Members are able to access after successfully logging in.
  • OpenAPI (Admin)
    Forms API

    Retrieve Forms via the public API endpoint using "where" filtering.
  • Extras
    ReCaptcha Styling

    WebinOne supports Google reCAPTCHA v2 and v3 implementations. Below are some additional options you can...

External Resources

There are currently no external resources available.

Please let us know if you have any other contributions or know of any helpful resources you'd like to see added here.


Questions?

We are always happy to help with any questions you may have.
Visit the Treepl Forum for community support and to search previously asked questions or send us a message at support@webinone.com and we will consult you as soon as possible.