This package builds and sends ajax requests from <form>
inputs. Then automatically receives upcoming validated request and provide automatical error messages management with all events required for Ajax management. Suitable for Laravel or plain PHP.
This is part of package for implementation in JavaScript / VueJs application side. More for PHP / Laravel side of this package on autoAjax
- Automatically builds request data from
<form>
input elements. - Handles Laravel validation and automatically binds error messages to each input in form.
- VueJs integration
- PlainJs integration
npm i autoajax --save
<!-- jQuery and jQuery form -->
<script src="https://code.jquery.com/jquery-2.2.4.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery.form/3.50/jquery.form.min.js"></script>
<!-- autoAjax.min.js -->
<script src="dist/autoAjax.min.js"></script>
var autoAjax = require('autoajax');
Vue.use(autoAjax);
If you want initialize autoAjax form in VueJS component, you need use v-autoAjax
directive in form element.
<template>
<form method="post" action="/contact" v-autoAjax="formOptions" v-autoAjaxRow="rowData" @onSubmit="onSubmit" @onSuccess="successEvent" @onValidation="validationEvent" @onError="errorEvent" @onComplete="onComplete">
<div class="form-group">
<input type="text" name="email">
</div>
<div class="form-group">
<textarea name="content"></textarea>
</div>
<div class="form-group">
<button type="submit">submit form</button>
</div>
</form>
</template>
<script>
export default {
data: {
rowData : {
email : 'example@example.com',
content : 'content',
},
formOptions : {
//...
}
},
methods: {
onSubmit(form) {
console.log(form);
},
successEvent(data, response) {
console.log(data, response);
},
errorEvent(data, response) {
console.log(data, response);
},
validationEvent(data, response) {
console.log(data, response);
},
onComplete(data, response) {
console.log(data, response);
}
}
}
</script>
Basic autoAjax form initialization you can bind with:
<form v-autoAjax></form>
For custom form options you can use directive with options parameter like:
<form v-autoAjax="myFormOptions"></form>
<form v-autoAjax v-autoReset></form>
<form v-autoAjax v-autoAjaxRow="myRowData"></form>
This is list of available form events. Need to be placed in form element.
@submit="mySubmitEvent"
or @onSubmit="mySubmitEvent"
@success="mySuccessEvent"
or @onSuccess="mySuccessEvent"
@error="myErrorEvent"
or @onError="myErrorEvent"
@validation="myValidationErrorEvent"
or @onValidation="myValidationErrorEvent"
@complete="myCompleteEvent"
or @onComplete="myCompleteEvent"
If you want initialize autoAjax form, you initialize autoAjax
method on your form element.
<form method="post" action="/contact" data-row="{ email : 'example@example.com' }" class="myAutoAjaxform">
<div class="form-group">
<input type="text" name="email">
</div>
<div class="form-group">
<textarea name="content"></textarea>
</div>
<div class="form-group">
<button type="submit">submit form</button>
</div>
</form>
<script>
$(function(){
var options = {
//Resets for on success response
autoReset : true,
onSubmit : function(data, response){},
onSuccess : function(data, response){},
onError : function(data, response){},
onValidation : function(data, response){},
onComplete : function(data, response){},
//Can be used also form without "on" at the beggining
// submit : function(data, response){...
// success : function(data, response){...
//and any other settings from autoAjax options...
};
$('form.myAutoAjaxform').autoAjax(options)
});
</script>
autoReset
- resets form values after success message
data-row
- JSON Value of data which will be binded into form fields.
AutoAjax options can be applied in VueJs directive v-autoAjax="myOptions"
or in jQuery initialization autoAjax on form element $('#myForm').autoAjax({ ... })
. This options will be applied only on selected form instance.
var options = {
//Automatically resets all form inputs to default values after success response
autoReset : false,
//Automaticaly add validation error messages after each bad filled input
showInputErrors : true,
//General success/error/validation form message
showMessage : true,
//Automaticaly add global validation error message into form message element
//showMessage needs to be true
showValidationMessage : true,
//Available selectors and classes
selectors : {
messageSelector: '.alert',
messageSuccessClass : '.alert-success',
messageErrorClass : '.alert-danger',
inputWrapperErrorClass : '.has-error',
},
//All available messages
messages : {
error : 'Something went wrong, please try again later.',
validation: 'Please fill all required fields.',
},
//Event on every form submit
onSubmit() => {},
//Event on success response (HTTP 200)
onSuccess() => {},
//Event on error response
onError() => {},
//Event on validation response
onValidation() => {},
//On all completed responses codes
onComplete() => {},
//Generate error message for input element
getErrorMessageElement(message, key, form) {
return '<span class="error-message error">'+message+'</span>';
},
//Add validation error message after this element
addErrorMessageAfterElement(input){
//You can modify, where should be placed validation error message for each input
//If you want place validation after input parent, you can do something like:
//return input.parent();
return input;
},
}
You can mutate global AutoAjax options for all form instances.
autoAjax.setOptions({
//Other settings from autoAjax options
//..
//Custom message
messages: {
error : 'My custom global error message',
},
//Custom error message element
getErrorMessageElement(message){
return '<span class="my-custom-error-message error">'+message+'</span>';
}
});