UNPKG

formvalidation

Version:

The best jQuery plugin to validate form fields. Support Bootstrap, Foundation, Pure, SemanticUI, UIKit and custom frameworks

176 lines (162 loc) 6.11 kB
<!DOCTYPE html> <html> <head> <title>FormValidation demo</title> <link rel="stylesheet" href="../vendor/bootstrap/css/bootstrap.css"/> <link rel="stylesheet" href="../dist/css/formValidation.css"/> <script type="text/javascript" src="../vendor/jquery/jquery.min.js"></script> <script type="text/javascript" src="../vendor/bootstrap/js/bootstrap.min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/typeahead.js/0.10.5/typeahead.jquery.js"></script> <script type="text/javascript" src="../dist/js/formValidation.js"></script> <script type="text/javascript" src="../dist/js/framework/bootstrap.js"></script> <style type="text/css"> /* https://github.com/bassjobsen/typeahead.js-bootstrap-css */ span.twitter-typeahead .tt-dropdown-menu { position: absolute; top: 100%; left: 0; z-index: 1000; display: none; float: left; min-width: 160px; padding: 5px 0; margin: 2px 0 0; list-style: none; font-size: 14px; text-align: left; background-color: #ffffff; border: 1px solid #cccccc; border: 1px solid rgba(0, 0, 0, 0.15); border-radius: 4px; -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175); box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175); background-clip: padding-box; } span.twitter-typeahead .tt-suggestion > p { display: block; padding: 3px 20px; clear: both; font-weight: normal; line-height: 1.42857143; color: #333333; white-space: nowrap; } span.twitter-typeahead .tt-suggestion > p:hover, span.twitter-typeahead .tt-suggestion > p:focus { color: #ffffff; text-decoration: none; outline: 0; background-color: #428bca; } span.twitter-typeahead .tt-suggestion.tt-cursor { color: #ffffff; background-color: #428bca; } span.twitter-typeahead { width: 100%; } .input-group span.twitter-typeahead { display: block !important; } .input-group span.twitter-typeahead .tt-dropdown-menu { top: 32px !important; } .input-group.input-group-lg span.twitter-typeahead .tt-dropdown-menu { top: 44px !important; } .input-group.input-group-sm span.twitter-typeahead .tt-dropdown-menu { top: 28px !important; } </style> </head> <body> <div class="container"> <div class="row"> <div class="col-xs-8 col-xs-offset-2"> <div class="page-header"> <h1>Using with typehead</h1> </div> <form id="typeheadForm" method="post" action="target.php"> <div class="form-group"> <input type="text" class="form-control" name="state" placeholder="US state" /> </div> <div class="form-group"> <button type="submit" class="btn btn-primary">Submit</button> </div> </form> </div> </div> </div> <script type="text/javascript"> $(document).ready(function() { var states = ['Alabama', 'Alaska', 'Arizona', 'Arkansas', 'California', 'Colorado', 'Connecticut', 'Delaware', 'Florida', 'Georgia', 'Hawaii', 'Idaho', 'Illinois', 'Indiana', 'Iowa', 'Kansas', 'Kentucky', 'Louisiana', 'Maine', 'Maryland', 'Massachusetts', 'Michigan', 'Minnesota', 'Mississippi', 'Missouri', 'Montana', 'Nebraska', 'Nevada', 'New Hampshire', 'New Jersey', 'New Mexico', 'New York', 'North Carolina', 'North Dakota', 'Ohio', 'Oklahoma', 'Oregon', 'Pennsylvania', 'Rhode Island', 'South Carolina', 'South Dakota', 'Tennessee', 'Texas', 'Utah', 'Vermont', 'Virginia', 'Washington', 'West Virginia', 'Wisconsin', 'Wyoming' ]; var substringMatcher = function(strs) { return function findMatches(q, cb) { var matches, substrRegex; // an array that will be populated with substring matches matches = []; // regex used to determine if a string contains the substring `q` substrRegex = new RegExp(q, 'i'); // iterate through the pool of strings and for any string that // contains the substring `q`, add it to the `matches` array $.each(strs, function(i, str) { if (substrRegex.test(str)) { // the typeahead jQuery plugin expects suggestions to a // JavaScript object, refer to typeahead docs for more info matches.push({ value: str }); } }); cb(matches); }; }; $('#typeheadForm').find('input[name="state"]') .typeahead({ hint: true, highlight: true, minLength: 1 }, { name: 'states', displayKey: 'value', source: substringMatcher(states) }) .on('typeahead:selected', function(e, suggestion, dataSetName) { // Revalidate the state field $('#typeheadForm').formValidation('revalidateField', 'state'); }) .on('typeahead:closed', function(e) { // Revalidate the state field $('#typeheadForm').formValidation('revalidateField', 'state'); }); $('#typeheadForm').formValidation({ icon: { valid: 'glyphicon glyphicon-ok', invalid: 'glyphicon glyphicon-remove', validating: 'glyphicon glyphicon-refresh' }, fields: { state: { validators: { notEmpty: { message: 'The state is required' }, stringLength: { min: 10, message: 'Please choose a state with at least 10 characters' } } } } }); }); </script> </body> </html>