298 lines
5.8 KiB
JavaScript
Vendored
298 lines
5.8 KiB
JavaScript
Vendored
"use strict";
|
|
|
|
// Class definition
|
|
var KTWizard2 = function () {
|
|
// Base elements
|
|
var _wizardEl;
|
|
var _formEl;
|
|
var _wizard;
|
|
var _validations = [];
|
|
|
|
// Private functions
|
|
var initWizard = function () {
|
|
// Initialize form wizard
|
|
_wizard = new KTWizard(_wizardEl, {
|
|
startStep: 1, // initial active step number
|
|
clickableSteps: false // to make steps clickable this set value true and add data-wizard-clickable="true" in HTML for class="wizard" element
|
|
});
|
|
|
|
// Validation before going to next page
|
|
_wizard.on('beforeNext', function (wizard) {
|
|
// Don't go to the next step yet
|
|
_wizard.stop();
|
|
|
|
// Validate form
|
|
var validator = _validations[wizard.getStep() - 1]; // get validator for currnt step
|
|
validator.validate().then(function (status) {
|
|
if (status == 'Valid') {
|
|
_wizard.goNext();
|
|
KTUtil.scrollTop();
|
|
} else {
|
|
Swal.fire({
|
|
text: "Sorry, looks like there are some errors detected, please try again.",
|
|
icon: "error",
|
|
buttonsStyling: false,
|
|
confirmButtonText: "Ok, got it!",
|
|
customClass: {
|
|
confirmButton: "btn font-weight-bold btn-light"
|
|
}
|
|
}).then(function () {
|
|
KTUtil.scrollTop();
|
|
});
|
|
}
|
|
});
|
|
});
|
|
|
|
// Change event
|
|
_wizard.on('change', function (wizard) {
|
|
KTUtil.scrollTop();
|
|
});
|
|
}
|
|
|
|
var initValidation = function () {
|
|
// Init form validation rules. For more info check the FormValidation plugin's official documentation:https://formvalidation.io/
|
|
// Step 1
|
|
_validations.push(FormValidation.formValidation(
|
|
_formEl,
|
|
{
|
|
fields: {
|
|
fname: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'First name is required'
|
|
}
|
|
}
|
|
},
|
|
lname: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Last Name is required'
|
|
}
|
|
}
|
|
},
|
|
phone: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Phone is required'
|
|
}
|
|
}
|
|
},
|
|
email: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Email is required'
|
|
},
|
|
emailAddress: {
|
|
message: 'The value is not a valid email address'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
plugins: {
|
|
trigger: new FormValidation.plugins.Trigger(),
|
|
bootstrap: new FormValidation.plugins.Bootstrap()
|
|
}
|
|
}
|
|
));
|
|
|
|
// Step 2
|
|
_validations.push(FormValidation.formValidation(
|
|
_formEl,
|
|
{
|
|
fields: {
|
|
address1: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Address is required'
|
|
}
|
|
}
|
|
},
|
|
postcode: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Postcode is required'
|
|
}
|
|
}
|
|
},
|
|
city: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'City is required'
|
|
}
|
|
}
|
|
},
|
|
state: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'State is required'
|
|
}
|
|
}
|
|
},
|
|
country: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Country is required'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
plugins: {
|
|
trigger: new FormValidation.plugins.Trigger(),
|
|
bootstrap: new FormValidation.plugins.Bootstrap()
|
|
}
|
|
}
|
|
));
|
|
|
|
// Step 3
|
|
_validations.push(FormValidation.formValidation(
|
|
_formEl,
|
|
{
|
|
fields: {
|
|
delivery: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Delivery type is required'
|
|
}
|
|
}
|
|
},
|
|
packaging: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Packaging type is required'
|
|
}
|
|
}
|
|
},
|
|
preferreddelivery: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Preferred delivery window is required'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
plugins: {
|
|
trigger: new FormValidation.plugins.Trigger(),
|
|
bootstrap: new FormValidation.plugins.Bootstrap()
|
|
}
|
|
}
|
|
));
|
|
|
|
// Step 4
|
|
_validations.push(FormValidation.formValidation(
|
|
_formEl,
|
|
{
|
|
fields: {
|
|
locaddress1: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Address is required'
|
|
}
|
|
}
|
|
},
|
|
locpostcode: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Postcode is required'
|
|
}
|
|
}
|
|
},
|
|
loccity: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'City is required'
|
|
}
|
|
}
|
|
},
|
|
locstate: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'State is required'
|
|
}
|
|
}
|
|
},
|
|
loccountry: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Country is required'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
plugins: {
|
|
trigger: new FormValidation.plugins.Trigger(),
|
|
bootstrap: new FormValidation.plugins.Bootstrap()
|
|
}
|
|
}
|
|
));
|
|
|
|
// Step 5
|
|
_validations.push(FormValidation.formValidation(
|
|
_formEl,
|
|
{
|
|
fields: {
|
|
ccname: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Credit card name is required'
|
|
}
|
|
}
|
|
},
|
|
ccnumber: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Credit card number is required'
|
|
},
|
|
creditCard: {
|
|
message: 'The credit card number is not valid'
|
|
}
|
|
}
|
|
},
|
|
ccmonth: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Credit card month is required'
|
|
}
|
|
}
|
|
},
|
|
ccyear: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Credit card year is required'
|
|
}
|
|
}
|
|
},
|
|
cccvv: {
|
|
validators: {
|
|
notEmpty: {
|
|
message: 'Credit card CVV is required'
|
|
},
|
|
digits: {
|
|
message: 'The CVV value is not valid. Only numbers is allowed'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
plugins: {
|
|
trigger: new FormValidation.plugins.Trigger(),
|
|
bootstrap: new FormValidation.plugins.Bootstrap()
|
|
}
|
|
}
|
|
));
|
|
}
|
|
|
|
return {
|
|
// public functions
|
|
init: function () {
|
|
_wizardEl = KTUtil.getById('kt_wizard_v2');
|
|
_formEl = KTUtil.getById('kt_form');
|
|
|
|
initWizard();
|
|
initValidation();
|
|
}
|
|
};
|
|
}();
|
|
|
|
jQuery(document).ready(function () {
|
|
KTWizard2.init();
|
|
});
|