Sneat uses default bootstrap validation and FormValidation to validate forms.
Read the
official
Bootstrap validation and
FormValidation Documentations
for a full list of instructions and other options.
You can use browser's inbuilt validation by using required
attribute with your form fields.
<form class="browser-default-validation col-md-6">
<div class="mb-4">
<label class="form-label" for="basic-default-name">Name</label>
<input type="text" class="form-control" id="basic-default-name" placeholder="John Doe" required />
</div>
<div class="mb-4">
<label class="form-label" for="basic-default-email">Email</label>
<input type="email" id="basic-default-email" class="form-control" placeholder="john.doe" required />
</div>
<div class="mb-4 form-password-toggle">
<label class="form-label" for="basic-default-password">Password</label>
<div class="input-group input-group-merge">
<input type="password" id="basic-default-password" class="form-control"
placeholder="············"
aria-describedby="basic-default-password3" required />
<span class="input-group-text cursor-pointer" id="basic-default-password3"><i
class="icon-base bx bx-hide"></i></span>
</div>
</div>
<div class="mb-4">
<label class="form-label" for="basic-default-country">Country</label>
<select class="form-select" id="basic-default-country" required>
<option value="">Select Country</option>
<option value="usa">USA</option>
<option value="uk">UK</option>
<option value="france">France</option>
<option value="australia">Australia</option>
<option value="spain">Spain</option>
</select>
</div>
<div class="mb-4">
<label class="form-label" for="basic-default-dob">DOB</label>
<input type="text" class="form-control flatpickr-validation" id="basic-default-dob" required />
</div>
<div class="mb-4">
<label class="form-label" for="basic-default-upload-file">Profile pic</label>
<input type="file" class="form-control" id="basic-default-upload-file" required />
</div>
<div class="mb-4">
<label class="d-block form-label">Gender</label>
<div class="form-check mb-2">
<input type="radio" id="basic-default-radio-male" name="basic-default-radio"
class="form-check-input" required checked />
<label class="form-check-label" for="basic-default-radio-male">Male</label>
</div>
<div class="form-check">
<input type="radio" id="basic-default-radio-female" name="basic-default-radio"
class="form-check-input" required />
<label class="form-check-label" for="basic-default-radio-female">Female</label>
</div>
</div>
<div class="mb-4">
<label class="form-label" for="basic-default-bio">Bio</label>
<textarea class="form-control" id="basic-default-bio" name="basic-default-bio" rows="3"
required></textarea>
</div>
<div class="mb-4">
<div class="form-check">
<input type="checkbox" class="form-check-input" id="basic-default-checkbox" required />
<label class="form-check-label" for="basic-default-checkbox">Agree to our terms and
conditions</label>
</div>
</div>
<div class="mb-4">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="browserDefaultSwitch" required />
<label class="form-check-label" for="browserDefaultSwitch">Send me related emails</label>
</div>
</div>
<div class="row">
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</div>
</form>
Bootstrap States
For custom Bootstrap form validation messages, you’ll need to add the novalidate
boolean
attribute to your <form>
. This disables the browser default feedback tooltips, but
still provides access to the form validation APIs in JavaScript. In the form below, we've used all of
the form related component of bootstrap. Try to submit the form, our JavaScript will intercept the
submit button and show you the current state of input fields.
You don't have to include any extra vendor files to validate your form using Bootstrap.
<form class="needs-validation" novalidate>
<div class="mb-4">
<label class="form-label" for="bs-validation-name">Name</label>
<input type="text" class="form-control" id="bs-validation-name" placeholder="John Doe"
required />
<div class="valid-feedback">Looks good!</div>
<div class="invalid-feedback">Please enter your name.</div>
</div>
<div class="mb-4">
<label class="form-label" for="bs-validation-email">Email</label>
<input type="email" id="bs-validation-email" class="form-control" placeholder="john.doe"
aria-label="john.doe" required />
<div class="valid-feedback">Looks good!</div>
<div class="invalid-feedback">Please enter a valid email</div>
</div>
<div class="mb-4 form-password-toggle">
<label class="form-label" for="bs-validation-password">Password</label>
<div class="input-group input-group-merge">
<input type="password" id="bs-validation-password" class="form-control"
placeholder="············"
required />
<span class="input-group-text cursor-pointer" id="basic-default-password4"><i
class="icon-base bx bx-hide"></i></span>
</div>
<div class="valid-feedback">Looks good!</div>
<div class="invalid-feedback">Please enter your password.</div>
</div>
<div class="mb-4">
<label class="form-label" for="bs-validation-country">Country</label>
<select class="form-select" id="bs-validation-country" required>
<option value="">Select Country</option>
<option value="usa">USA</option>
<option value="uk">UK</option>
<option value="france">France</option>
<option value="australia">Australia</option>
<option value="spain">Spain</option>
</select>
<div class="valid-feedback">Looks good!</div>
<div class="invalid-feedback">Please select your country</div>
</div>
<div class="mb-4">
<label class="form-label" for="bs-validation-dob">DOB</label>
<input type="text" class="form-control flatpickr-validation" id="bs-validation-dob"
required />
<div class="valid-feedback">Looks good!</div>
<div class="invalid-feedback">Please Enter Your DOB</div>
</div>
<div class="mb-4">
<label class="form-label" for="bs-validation-upload-file">Profile pic</label>
<input type="file" class="form-control" id="bs-validation-upload-file" required />
</div>
<div class="mb-4">
<label class="d-block form-label">Gender</label>
<div class="form-check mb-2">
<input type="radio" id="bs-validation-radio-male" name="bs-validation-radio"
class="form-check-input" required checked />
<label class="form-check-label" for="bs-validation-radio-male">Male</label>
</div>
<div class="form-check">
<input type="radio" id="bs-validation-radio-female" name="bs-validation-radio"
class="form-check-input" required />
<label class="form-check-label" for="bs-validation-radio-female">Female</label>
</div>
</div>
<div class="mb-4">
<label class="form-label" for="bs-validation-bio">Bio</label>
<textarea class="form-control" id="bs-validation-bio" name="bs-validation-bio" rows="3"
required></textarea>
</div>
<div class="mb-4">
<div class="form-check">
<input type="checkbox" class="form-check-input" id="bs-validation-checkbox" required />
<label class="form-check-label" for="bs-validation-checkbox">Agree to our terms and
conditions</label>
<div class="invalid-feedback">You must agree before submitting.</div>
</div>
</div>
<div class="mb-4">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="bootstrapValidationSwitch" required />
<label class="form-check-label" for="bootstrapValidationSwitch">Send me related
emails</label>
</div>
</div>
<div class="row">
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</div>
</form>
// Flat pickr
const flatPickrList = [].slice.call(document.querySelectorAll('.flatpickr-validation'));
if (flatPickrList) {
flatPickrList.forEach(flatPickr => {
flatPickr.flatpickr({
allowInput: true,
monthSelectorType: 'static'
});
});
}
// Fetch all the forms we want to apply custom Bootstrap validation styles to
const bsValidationForms = document.querySelectorAll('.needs-validation');
// Loop over them and prevent submission
Array.prototype.slice.call(bsValidationForms).forEach(function (form) {
form.addEventListener(
'submit',
function (event) {
if (!form.checkValidity()) {
event.preventDefault();
event.stopPropagation();
} else {
// Submit your form
alert('Submitted!!!');
}
form.classList.add('was-validated');
},
false
);
});
Server Side
We recommend using client-side validation, but in case you require server-side validation, you can
indicate invalid and valid form fields with .is-invalid
and
.is-valid
respectively. Note that .invalid-feedback
is also supported with
these classes.
<form class="needs-validation" novalidate>
<div class="mb-3">
<label class="form-label" for="bs-validation-server-name">Name</label>
<input type="text" class="form-control is-valid" id="bs-validation-server-name" placeholder="John Doe" value="John Doe" required />
<div class="valid-feedback">
Looks good!
</div>
</div>
<div class="mb-3">
<label class="form-label" for="bs-validation-server-email">Email</label>
<input type="text" id="bs-validation-server-email" class="form-control is-invalid" placeholder="john.doe" aria-label="john.doe" required />
<div class="invalid-feedback">
Please enter a valid email
</div>
</div>
<div class="mb-3 form-password-toggle">
<label class="form-label" for="bs-validation-server-password">Password</label>
<input type="password" id="bs-validation-server-password" class="form-control is-invalid" placeholder="············" required />
<div class="invalid-feedback">
Please enter your password.
</div>
</div>
<div class="mb-3">
<label class="form-label" for="bs-validation-server-country">Country</label>
<select class="form-select is-valid" id="bs-validation-server-country" required>
<option value="">Select Country</option>
<option value="usa">USA</option>
<option value="uk" selected>UK</option>
<option value="france">France</option>
<option value="australia">Australia</option>
<option value="spain">Spain</option>
</select>
<div class="valid-feedback">
Looks good!
</div>
</div>
<div class="mb-3">
<label class="form-label" for="bs-validation-server-dob">DOB</label>
<input type="text" class="form-control flatpickr-validation is-invalid" id="bs-validation-server-dob" required />
<div class="invalid-feedback">
Please Enter Your DOB
</div>
</div>
<div class="mb-3">
<label class="form-label" class="d-block form-label">Gender</label>
<div class="form-check mb-2">
<input type="radio" id="bs-validation-server-radio-male" name="bs-validation-server-radio" class="form-check-input is-invalid" required />
<label class="form-check-label" for="bs-validation-server-radio-male">Male</label>
</div>
<div class="form-check">
<input type="radio" id="bs-validation-server-radio-female" name="bs-validation-server-radio" class="form-check-input is-invalid" required />
<label class="form-check-label" for="bs-validation-server-radio-female">Female</label>
</div>
</div>
<div class="mb-3">
<label class="form-label" class="form-label" for="bs-validation-server-bio">Bio</label>
<textarea class="form-control is-valid" id="bs-validation-server-bio" name="validationBioBootstrap" rows="3" required>Something about me..</textarea>
</div>
<div class="mb-3">
<div class="form-check">
<input type="checkbox" class="form-check-input is-invalid" id="bs-validation-server-checkbox" required />
<label class="form-check-label" for="bs-validation-server-checkbox">Agree to our terms and conditions</label>
<div class="invalid-feedback">
You must agree before submitting.
</div>
</div>
</div>
<div class="mb-3">
<div class="form-check form-switch">
<input type="checkbox" class="form-check-input is-valid" id="relatedEmailsSwitch" checked required />
<label class="form-check-label" for="relatedEmailsSwitch">Send me related emails</label>
</div>
</div>
<div class="row">
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</div>
</form>
Tooltip
If your form layout allows it, you can swap the .{valid|invalid}-feedback
classes for
.{valid|invalid}-tooltip
classes to display validation feedback in a styled tooltip. Be
sure to have a parent with position: relative
on it for tooltip positioning.
<form class="needs-validation" novalidate>
<div class="position-relative mb-12">
<label class="form-label" for="bs-validation-tooltip-name">Name</label>
<input type="text" class="form-control is-valid" id="bs-validation-tooltip-name" placeholder="John Doe" value="John Doe" required />
<div class="valid-tooltip">
Looks good!
</div>
</div>
<div class="position-relative mb-12">
<label class="form-label" for="bs-validation-tooltip-email">Email</label>
<input type="text" id="bs-validation-tooltip-email" class="form-control is-invalid" placeholder="john.doe" aria-label="john.doe" required />
<div class="invalid-tooltip">
Please enter a valid email
</div>
</div>
<div class="position-relative mb-12 form-password-toggle">
<label class="form-label" for="bs-validation-tooltip-password">Password</label>
<input type="password" id="bs-validation-tooltip-password" class="form-control is-invalid" placeholder="············" required />
<div class="invalid-tooltip">
Please enter your password.
</div>
</div>
<div class="position-relative mb-12">
<label class="form-label" for="bs-validation-tooltip-country">Country</label>
<select class="form-select is-valid" id="bs-validation-tooltip-country" required>
<option value="">Select Country</option>
<option value="usa">USA</option>
<option value="uk" selected>UK</option>
<option value="france">France</option>
<option value="australia">Australia</option>
<option value="spain">Spain</option>
</select>
<div class="valid-tooltip">
Looks good!
</div>
</div>
<div class="position-relative mb-12">
<label class="form-label" for="bs-validation-tooltip-dob">DOB</label>
<input type="text" class="form-control flatpickr-validation is-invalid" id="bs-validation-tooltip-dob" required />
<div class="invalid-tooltip">
Please Enter Your DOB
</div>
</div>
<div class="position-relative mb-12">
<label class="form-label" for="bs-validation-tooltip-bio">Bio</label>
<textarea class="form-control is-valid" id="bs-validation-tooltip-bio" name="bs-validation-tooltip-bio" rows="3" required>Something about me..</textarea>
<div class="valid-tooltip">
Looks Good
</div>
</div>
<div class="row">
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</div>
</form>
The all new FormValidation a validation library for JavaScript with zero dependencies. FormValidation is the primary validation library for this template, used in pages, apps & other forms.
Features
Usage
In order to use FormValidation on your page, It is required to include the following vendors css in the "Vendors CSS" area from the page's header:
For more details on usage please refer formValidation's getting started guide.
Tips: Following are the helpful articles in order to use this plugin
FAQ: Uncaught TypeError: Cannot read property 'classList' of null
Make sure you structure form accordingly or define rowSelector
. The rowSelector option
will be used to help the plugin determine the field containers. Default rowSelector
for
this plugin is .row
. Refer
Integrate with Bootstrap 5 framework.
for more details.
<link rel="stylesheet" href="assets/vendor/libs/@form-validation/form-validation.css" />
Include the following vendors script in the "Vendors JS" area from the page's footer:
<script src="assets/vendor/libs/@form-validation/popular.js"></script>
<script src="assets/vendor/libs/@form-validation/bootstrap5.js"></script>
<!-- AutoFocus plugin, automatically focus on the first invalid input -->
<script src="assets/vendor/libs/@form-validation/auto-focus.js"></script>
Example
In this example, we've tried to cover as many form inputs as we can. Though If we've miss any third party libraries, then refer Integrating with 3rd party libraries.
<form id="formValidationExamples" class="row g-3">
<!-- Account Details -->
<div class="col-12">
<h6>1. Account Details</h6>
<hr class="mt-0" />
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationName">Full Name</label>
<input type="text" id="formValidationName" class="form-control" placeholder="John Doe" name="formValidationName" />
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationEmail">Email</label>
<input class="form-control" type="email" id="formValidationEmail" name="formValidationEmail" placeholder="john.doe" />
</div>
<div class="col-md-6 form-control-validation">
<div class="form-password-toggle">
<label class="form-label" for="formValidationPass">Password</label>
<div class="input-group input-group-merge">
<input class="form-control" type="password" id="formValidationPass" name="formValidationPass" placeholder="············" aria-describedby="multicol-password2" />
<span class="input-group-text cursor-pointer" id="multicol-password2"><i class="icon-base bx bx-hide"></i></span>
</div>
</div>
</div>
<div class="col-md-6 form-control-validation">
<div class="form-password-toggle">
<label class="form-label" for="formValidationConfirmPass">Confirm Password</label>
<div class="input-group input-group-merge">
<input class="form-control" type="password" id="formValidationConfirmPass" name="formValidationConfirmPass" placeholder="············" aria-describedby="multicol-confirm-password2" />
<span class="input-group-text cursor-pointer" id="multicol-confirm-password2"><i class="icon-base bx bx-hide"></i></span>
</div>
</div>
</div>
<!-- Personal Info -->
<div class="col-12">
<h6 class="mt-2">2. Personal Info</h6>
<hr class="mt-0" />
</div>
<div class="col-md-6 form-control-validation">
<label for="formValidationFile" class="form-label">Profile Pic</label>
<input class="form-control" type="file" id="formValidationFile" name="formValidationFile" />
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationDob">DOB</label>
<input type="text" class="form-control flatpickr-validation" name="formValidationDob" id="formValidationDob" required />
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationSelect2">Country</label>
<select id="formValidationSelect2" name="formValidationSelect2" class="form-select select2" data-allow-clear="true">
<option value="">Select</option>
<option value="Australia">Australia</option>
<option value="Bangladesh">Bangladesh</option>
<option value="Belarus">Belarus</option>
<option value="Brazil">Brazil</option>
<option value="Canada">Canada</option>
<option value="China">China</option>
<option value="France">France</option>
<option value="Germany">Germany</option>
<option value="India">India</option>
<option value="Indonesia">Indonesia</option>
<option value="Israel">Israel</option>
<option value="Italy">Italy</option>
<option value="Japan">Japan</option>
<option value="Korea">Korea, Republic of</option>
<option value="Mexico">Mexico</option>
<option value="Philippines">Philippines</option>
<option value="Russia">Russian Federation</option>
<option value="South Africa">South Africa</option>
<option value="Thailand">Thailand</option>
<option value="Turkey">Turkey</option>
<option value="Ukraine">Ukraine</option>
<option value="United Arab Emirates">United Arab Emirates</option>
<option value="United Kingdom">United Kingdom</option>
<option value="United States">United States</option>
</select>
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationLang">Languages</label>
<input type="text" value="" class="form-control" name="formValidationLang" id="formValidationLang" />
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationTech">Tech</label>
<input class="form-control typeahead" type="text" id="formValidationTech" name="formValidationTech" autocomplete="off" />
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationHobbies">Hobbies</label>
<select class="selectpicker hobbies-select w-100" id="formValidationHobbies" data-style="btn-default" data-icon-base="icon-base bx" data-tick-icon="bx-check text-primary" name="formValidationHobbies" multiple>
<option>Sports</option>
<option>Movies</option>
<option>Books</option>
</select>
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label" for="formValidationBio">Bio</label>
<textarea class="form-control" id="formValidationBio" name="formValidationBio" rows="3"></textarea>
</div>
<div class="col-md-6 form-control-validation">
<label class="form-label">Gender</label>
<div class="form-check custom mb-2">
<input type="radio" id="formValidationGender" name="formValidationGender" class="form-check-input" checked />
<label class="form-check-label" for="formValidationGender">Male</label>
</div>
<div class="form-check custom">
<input type="radio" id="formValidationGender2" name="formValidationGender" class="form-check-input" />
<label class="form-check-label" for="formValidationGender2">Female</label>
</div>
</div>
<!-- Choose Your Plan -->
<div class="col-12">
<h6 class="mt-2">3. Choose Your Plan</h6>
<hr class="mt-0" />
</div>
<div class="row gy-3 mt-0">
<div class="col-xl-3 col-md-5 col-sm-6 col-12 form-control-validation">
<div class="form-check custom-option custom-option-icon">
<label class="form-check-label custom-option-content" for="basicPlanMain1">
<span class="custom-option-body">
<i class="icon-base bx bx-rocket"></i>
<span class="custom-option-title"> Starter </span>
<small> Get 5gb of space and 1 team member. </small>
</span>
<input name="formValidationPlan" class="form-check-input" type="radio" value="" id="basicPlanMain1" checked />
</label>
</div>
</div>
<div class="col-xl-3 col-md-5 col-sm-6 col-12 form-control-validation">
<div class="form-check custom-option custom-option-icon">
<label class="form-check-label custom-option-content" for="basicPlanMain2">
<span class="custom-option-body">
<i class="icon-base bx bx-user"></i>
<span class="custom-option-title"> Personal </span>
<small> Get 15gb of space and 5 team member. </small>
</span>
<input name="formValidationPlan" class="form-check-input" type="radio" value="" id="basicPlanMain2" />
</label>
</div>
</div>
<div class="col-xl-3 col-md-5 col-sm-6 col-12 form-control-validation">
<div class="form-check custom-option custom-option-icon">
<label class="form-check-label custom-option-content" for="basicPlanMain3">
<span class="custom-option-body">
<i class="icon-base bx bx-crown"></i>
<span class="custom-option-title"> Premium </span>
<small> Get 25gb of space and 15 members. </small>
</span>
<input name="formValidationPlan" class="form-check-input" type="radio" value="" id="basicPlanMain3" />
</label>
</div>
</div>
</div>
<div class="col-12 form-control-validation">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="formValidationSwitch" name="formValidationSwitch" required />
<label class="form-check-label" for="formValidationSwitch">Send me related emails</label>
</div>
</div>
<div class="col-12 form-control-validation">
<div class="form-check">
<input type="checkbox" class="form-check-input" id="formValidationCheckbox" name="formValidationCheckbox" />
<label class="form-check-label" for="formValidationCheckbox">Agree to our terms and conditions</label>
</div>
</div>
<div class="col-12 form-control-validation">
<button type="submit" name="submitButton" class="btn btn-primary">Submit</button>
</div>
</form>
document.addEventListener('DOMContentLoaded', function (e) {
(function () {
const formValidationExamples = document.getElementById('formValidationExamples'),
formValidationSelect2Ele = jQuery(formValidationExamples.querySelector('[name="formValidationSelect2"]')),
formValidationTechEle = jQuery(formValidationExamples.querySelector('[name="formValidationTech"]')),
formValidationLangEle = formValidationExamples.querySelector('[name="formValidationLang"]'),
formValidationHobbiesEle = jQuery(formValidationExamples.querySelector('.selectpicker')),
tech = [
'ReactJS',
'Angular',
'VueJS',
'Html',
'Css',
'Sass',
'Pug',
'Gulp',
'Php',
'Laravel',
'Python',
'Bootstrap',
'Material Design',
'NodeJS'
];
const fv = FormValidation.formValidation(formValidationExamples, {
fields: {
formValidationName: {
validators: {
notEmpty: {
message: 'Please enter your name'
},
stringLength: {
min: 6,
max: 30,
message: 'The name must be more than 6 and less than 30 characters long'
},
regexp: {
regexp: /^[a-zA-Z0-9 ]+$/,
message: 'The name can only consist of alphabetical, number and space'
}
}
},
formValidationEmail: {
validators: {
notEmpty: {
message: 'Please enter your email'
},
emailAddress: {
message: 'The value is not a valid email address'
}
}
},
formValidationPass: {
validators: {
notEmpty: {
message: 'Please enter your password'
}
}
},
formValidationConfirmPass: {
validators: {
notEmpty: {
message: 'Please confirm password'
},
identical: {
compare: function () {
return formValidationExamples.querySelector('[name="formValidationPass"]').value;
},
message: 'The password and its confirm are not the same'
}
}
},
formValidationFile: {
validators: {
notEmpty: {
message: 'Please select the file'
}
}
},
formValidationDob: {
validators: {
notEmpty: {
message: 'Please select your DOB'
},
date: {
format: 'YYYY/MM/DD',
message: 'The value is not a valid date'
}
}
},
formValidationSelect2: {
validators: {
notEmpty: {
message: 'Please select your country'
}
}
},
formValidationLang: {
validators: {
notEmpty: {
message: 'Please add your language'
}
}
},
formValidationTech: {
validators: {
notEmpty: {
message: 'Please select technology'
}
}
},
formValidationHobbies: {
validators: {
notEmpty: {
message: 'Please select your hobbies'
}
}
},
formValidationBio: {
validators: {
notEmpty: {
message: 'Please enter your bio'
},
stringLength: {
min: 100,
max: 500,
message: 'The bio must be more than 100 and less than 500 characters long'
}
}
},
formValidationGender: {
validators: {
notEmpty: {
message: 'Please select your gender'
}
}
},
formValidationPlan: {
validators: {
notEmpty: {
message: 'Please select your preferred plan'
}
}
},
formValidationSwitch: {
validators: {
notEmpty: {
message: 'Please select your preference'
}
}
},
formValidationCheckbox: {
validators: {
notEmpty: {
message: 'Please confirm our T&C'
}
}
}
},
plugins: {
trigger: new FormValidation.plugins.Trigger(),
bootstrap5: new FormValidation.plugins.Bootstrap5({
// Use this for enabling/changing valid/invalid class
// eleInvalidClass: '',
eleValidClass: '',
rowSelector: function (field, ele) {
// field is the field name & ele is the field element
switch (field) {
case 'formValidationName':
case 'formValidationEmail':
case 'formValidationPass':
case 'formValidationConfirmPass':
case 'formValidationFile':
case 'formValidationDob':
case 'formValidationSelect2':
case 'formValidationLang':
case 'formValidationTech':
case 'formValidationHobbies':
case 'formValidationBio':
case 'formValidationGender':
case 'formValidationPlan':
case 'formValidationSwitch':
case 'formValidationCheckbox':
return '.form-control-validation';
default:
return '.row';
}
}
}),
submitButton: new FormValidation.plugins.SubmitButton(),
// Submit the form when all fields are valid
defaultSubmit: new FormValidation.plugins.DefaultSubmit(),
autoFocus: new FormValidation.plugins.AutoFocus()
},
init: instance => {
instance.on('plugins.message.placed', function (e) {
//* Move the error message out of the `input-group` element
if (e.element.parentElement.classList.contains('input-group')) {
// `e.field`: The field name
// `e.messageElement`: The message element
// `e.element`: The field element
e.element.parentElement.insertAdjacentElement('afterend', e.messageElement);
}
//* Move the error message out of the `row` element for custom-options
if (e.element.parentElement.parentElement.classList.contains('custom-option')) {
e.element.closest('.row').insertAdjacentElement('afterend', e.messageElement);
}
});
}
});
//? Revalidation third-party libs inputs on change trigger
// Flatpickr
const flatpickrDate = document.querySelector('[name="formValidationDob"]');
if (flatpickrDate) {
flatpickrDate.flatpickr({
enableTime: false,
// See https://flatpickr.js.org/formatting/
dateFormat: 'Y/m/d',
// After selecting a date, we need to revalidate the field
onChange: function () {
fv.revalidateField('formValidationDob');
}
});
}
// Select2 (Country)
if (formValidationSelect2Ele.length) {
formValidationSelect2Ele.wrap('<div class="position-relative"></div>');
formValidationSelect2Ele
.select2({
placeholder: 'Select country',
dropdownParent: formValidationSelect2Ele.parent()
})
.on('change', function () {
// Revalidate the color field when an option is chosen
fv.revalidateField('formValidationSelect2');
});
}
// Typeahead
// String Matcher function for typeahead
const substringMatcher = function (strs) {
return function findMatches(q, cb) {
var matches, substrRegex;
matches = [];
substrRegex = new RegExp(q, 'i');
$.each(strs, function (i, str) {
if (substrRegex.test(str)) {
matches.push(str);
}
});
cb(matches);
};
};
// Check if rtl
if (isRtl) {
const typeaheadList = [].slice.call(document.querySelectorAll('.typeahead'));
// Flat pickr
if (typeaheadList) {
typeaheadList.forEach(typeahead => {
typeahead.setAttribute('dir', 'rtl');
});
}
}
formValidationTechEle.typeahead(
{
hint: !isRtl,
highlight: true,
minLength: 1
},
{
name: 'tech',
source: substringMatcher(tech)
}
);
// Tagify
let formValidationLangTagify = new Tagify(formValidationLangEle);
formValidationLangEle.addEventListener('change', onChange);
function onChange() {
fv.revalidateField('formValidationLang');
}
//Bootstrap select
formValidationHobbiesEle.on('changed.bs.select', function (e, clickedIndex, isSelected, previousValue) {
fv.revalidateField('formValidationHobbies');
});
})();
});