Skip to content

Latest commit

 

History

History
198 lines (156 loc) · 10.7 KB

ajax-javascript-api.md

File metadata and controls

198 lines (156 loc) · 10.7 KB

JavaScript API

Introduction

The JavaScript API is more powerful than the data attributes API. The request method can be used with any element that is inside a form, or on a form element. When the method is used with an element inside a form, it is forwarded to the form.

The request method has a single required argument - the AJAX handler name. Example:

<form onsubmit="$(this).request('onProcess'); return false;">
    ...

The second argument of the request method is the options object. You can use any option and method compatible with the jQuery AJAX function. The following options are specific for the Winter framework:

<style> .attributes-table-precessor + table td:first-child, .attributes-table-precessor + table td:first-child > * { white-space: nowrap; } </style>
Option Description
update an object, specifies a list partials and page elements (as CSS selectors) to update: {'partial': '#select'}. If the selector string is prepended with the @ symbol, the content received from the server will be appended to the element, instead of replacing the existing content.
confirm the confirmation string. If set, the confirmation is displayed before the request is sent. If the user clicks the Cancel button, the request cancels.
data an optional object specifying data to be sent to the server along with the form data: {var: 'value'}. When files is true, you may also include files to be uploaded in this object by using Blob objects. To specify the filename of any Blob objects, simply set the filename property on the Blob object. (Ex. var blob = new Blob(variable); blob.filename = 'test.txt'; var data = {'uploaded_file': blob};)
redirect string specifying an URL to redirect the browser to after the successful request.
beforeUpdate a callback function to execute before page elements are updated. The function gets 3 parameters: the data object received from the server, text status string, and the jqXHR object. The this variable inside the function resolves to the request content - an object containing 2 properties: handler and options representing the original request() parameters.
success a callback function to execute in case of a successful request. If this option is supplied it overrides the default framework's functionality: the elements are not updated, the beforeUpdate event is not triggered, the ajaxUpdate and ajaxUpdateComplete events are not triggered. The event handler gets 3 arguments: the data object received from the server, the text status string and the jqXHR object. However, you can still call the default framework functionality calling this.success(...) inside your function.
error a callback function execute in case of an error. By default the alert message is displayed. If this option is overridden the alert message won't be displayed. The handler gets 3 parameters: the jqXHR object, the text status string and the error object - see jQuery AJAX function.
complete a callback function execute in case of a success or an error.
form a form element to use for sourcing the form data sent with the request, either passed as a selector string or a form element.
flash when true, instructs the server to clear and send any flash messages with the response. default: false
files when true, the request will accept file uploads, this requires FormData interface support by the browser. default: false
browserValidate when true, browser-based client side validation will be performed on the request before submitting. This only applies to requests triggered in the context of a <form> element. NOTE: This form of validation does not play nice with complex forms where validated fields might not be visible to the user 100% of the time. Recommend that you avoid using it on anything but the most simple forms.
loading an optional string or object to be displayed when a request runs. The string should be a CSS selector for an element, the object should support the show() and hide() functions to manage the visibility. You may pass the global object $.wn.stripeLoadIndicator when using the framework extras.

You may also override some of the request logic by passing new functions as options. These logic handlers are available.

<style> .attributes-table-precessor + table td:first-child, .attributes-table-precessor + table td:first-child > * { white-space: nowrap; } </style>
Handler Description
handleConfirmMessage(message) called when requesting confirmation from the user.
handleErrorMessage(message) called when an error message should be displayed.
handleValidationMessage(message, fields) focuses the first invalid field when validation is used.
handleFlashMessage(message, type) called when a flash message is provided using the flash option (see above).
handleRedirectResponse(url) called when the browser should redirect to another location.

Usage examples

Request a confirmation before the onDelete request is sent:

$('form').request('onDelete', {
    confirm: 'Are you sure?',
    redirect: '/dashboard'
})

Run onCalculate handler and inject the rendered calcresult partial into the page element with the result CSS class:

$('form').request('onCalculate', {
    update: {calcresult: '.result'}
})

Run onCalculate handler with some extra data:

$('form').request('onCalculate', {data: {value: 55}})

Run onCalculate handler and run some custom code before the page elements update:

$('form').request('onCalculate', {
    update: {calcresult: '.result'},
    beforeUpdate: function() { /* do something */ }
})

Run onCalculate handler and if successful, run some custom code and the default success function:

$('form').request('onCalculate', {success: function(data) {
    //... do something ...
    this.success(data);
}})

Execute a request without a FORM element:

$.request('onCalculate', {
    success: function() {
        console.log('Finished!');
    }
})

Run onCalculate handler and if successful, run some custom code after the default success function is done:

$('form').request('onCalculate', {success: function(data) {
    this.success(data).done(function() {
        //... do something after parent success() is finished ...
    });
}})

Global AJAX events

The AJAX framework triggers several events on the updated elements, triggering element, form, and the window object. The events are triggered regardless on which API was used - the data attributes API or the JavaScript API.

<style> .attributes-table-precessor + table td:first-child, .attributes-table-precessor + table td:first-child > * { white-space: nowrap; } </style>
Event Description
ajaxBeforeSend triggered on the window object before sending the request.
ajaxBeforeUpdate triggered on the form object directly after the request is complete, but before the page is updated. The handler gets 5 parameters: the event object, the context object, the data object received from the server, the status text string, and the jqXHR object.
ajaxUpdate triggered on a page element after it has been updated with the framework. The handler gets 5 parameters: the event object, the context object, the data object received from the server, the status text string, and the jqXHR object.
ajaxUpdateComplete triggered on the window object after all elements are updated by the framework. The handler gets 5 parameters: the event object, the context object, the data object received from the server, the status text string, and the jqXHR object.
ajaxSuccess triggered on the form object after the request is successfully completed. The handler gets 5 parameters: the event object, the context object, the data object received from the server, the status text string, and the jqXHR object.
ajaxError triggered on the form object if the request encounters an error. The handler gets 5 parameters: the event object, the context object, the error message, the status text string, and the jqXHR object.
ajaxErrorMessage triggered on the window object if the request encounters an error. The handler gets 2 parameters: the event object and error message returned from the server.
ajaxConfirmMessage triggered on the window object when confirm option is given. The handler gets 2 parameters: the event object and text message assigned to the handler as part of confirm option. This is useful for implementing custom confirm logic/interface instead of native javascript confirm box.

These events are fired on the triggering element:

Event Description
ajaxSetup triggered before the request is formed, allowing options to be modified via the context.options object.
ajaxPromise triggered directly before the AJAX request is sent.
ajaxFail triggered finally if the AJAX request fails.
ajaxDone triggered finally if the AJAX request was successful.
ajaxAlways triggered regardless if the AJAX request fails or was successful.

Usage examples

Executes JavaScript code when the ajaxUpdate event is triggered on an element.

$('.calcresult').on('ajaxUpdate', function() {
    console.log('Updated!');
})

Execute a single request that shows a Flash Message using logic handler.

$.request('onDoSomething', {
    flash: 1,
    handleFlashMessage: function(message, type) {
        $.wn.flashMsg({ text: message, class: type })
    }
})

Applies configurations to all AJAX requests globally.

$(document).on('ajaxSetup', function(event, context) {
    // Enable AJAX handling of Flash messages on all AJAX requests
    context.options.flash = true

    // Enable the StripeLoadIndicator on all AJAX requests
    context.options.loading = $.wn.stripeLoadIndicator

    // Handle Error Messages by triggering a flashMsg of type error
    context.options.handleErrorMessage = function(message) {
        $.wn.flashMsg({ text: message, class: 'error' })
    }

    // Handle Flash Messages by triggering a flashMsg of the message type
    context.options.handleFlashMessage = function(message, type) {
        $.wn.flashMsg({ text: message, class: type })
    }
})