"use strict"; // Class definition var KTProjectsAdd = function () { // Base elements var _wizardEl; var _formEl; var _wizard; var _avatar; var _validations = []; // Private functions var initWizard = function () { // Initialize form wizard _wizard = new KTWizard(_wizardEl, { startStep: 1, // initial active step number clickableSteps: true // allow step clicking }); // 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(); }); } // Form Validation 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: { projectname: { validators: { notEmpty: { message: 'Project name is required' } } }, projectowner: { validators: { notEmpty: { message: 'Project owner is required' } } }, customername: { validators: { notEmpty: { message: 'Customer name is required' } } }, phone: { validators: { notEmpty: { message: 'Phone is required' }, phone: { country: 'US', message: 'The value is not a valid US phone number. (e.g 5554443333)' } } }, email: { validators: { notEmpty: { message: 'Email is required' }, emailAddress: { message: 'The value is not a valid email address' } } }, companywebsite: { validators: { notEmpty: { message: 'Website URL is required' } } } }, plugins: { trigger: new FormValidation.plugins.Trigger(), bootstrap: new FormValidation.plugins.Bootstrap() } } )); // Step 2 _validations.push(FormValidation.formValidation( _formEl, { fields: { // Step 2 communication: { validators: { choice: { min: 1, message: 'Please select at least 1 option' } } }, language: { validators: { notEmpty: { message: 'Please select a language' } } }, timezone: { validators: { notEmpty: { message: 'Please select a timezone' } } } }, plugins: { trigger: new FormValidation.plugins.Trigger(), bootstrap: new FormValidation.plugins.Bootstrap() } } )); // Step 3 _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() } } )); } var initAvatar = function () { _avatar = new KTImageInput('kt_projects_add_avatar'); } return { // public functions init: function () { _wizardEl = KTUtil.getById('kt_projects_add'); _formEl = KTUtil.getById('kt_projects_add_form'); initWizard(); initValidation(); initAvatar(); } }; }(); jQuery(document).ready(function () { KTProjectsAdd.init(); });