History: Tracker Field Validation
Source of version: 12
Copy to clipboard
! Tracker Field Validation !! jQuery AJAX validation In ((Tiki6)), jQuery AJAX validation was introduced. It works perfectly with fields that take text input but is not really suited or relevant to fields that have pre-configured selections, etc. (drop downs). The Validation feature, under jQuery plugins and add-ons settings in the Features → Interface panel has to be enabled for this to work. When editing or adding a tracker field while configuring a tracker, you can choose a validation option. So far, the following validation procedures }have been added: __distinct__: Checks if the input text has been used before in the tracker for this field - thus ensuring all tracker items can be unique with respect to the validated field __username__: Checks if username has been used already and is valid according to the rules configured in Tiki __password__: Checks if the password is valid according to the rules configured in Tiki __regex__: checks the entered text against any perl regular expression. Enter the regular expression as the "Validation parameter". (Do not include the starting and ending "/" enclosing the regular expression. These will be added automatically.) Not all validation methods require a "Validation parameter" to be set. Regardless of which validation method is selected, you can specify a default custom error message if desired, in "Validation error message:" !!!Adding new custom validation procedures Developers can add new custom validation procedures in lib/validators. Each validator must be stored in a php file named "validator_nameofvalidator.php" and there must be a main function in the file with the general structure as follows: {CODE()} function validator_nameofvalidator($input, $parameter = '', $message = '') { … … … if ($error) { return tra($message); // error message to be shown } return true; // successful validation } {CODE} It is also necessary to add a line in file ''lib/core/Services/Tracker/Controller.php'' in the list of all validators {CODE(caption="lib/core/Services/Tracker/Controller.php" wrap="1" colors="php")} 'regex' => tr('Regular Expression (Pattern)'), 'username' => tr('User Name'), 'nameofvalidator' => tr('My Validator I Wrote by Myself'),{CODE} $parameter will be what is configured as the "Validation parameter:" in the tracker field settings, and $message is what is configured as the "Validation error message:" in the tracker field settings. You don't have to return $message as the error message if you don't want to (you can return any error message you want depending on the type of the error it is). !!Adding custom per-page validation Since Tiki 9.1, it is possible to add custom validation in a wiki page which contains a Tracker plugin through jQuery. If the jQuery validation fails, it should set: nosubmitItemForm1 = true; for the first tracker plugin, nosubmitItemForm2 for the second, etc. Example validation for a field of type "ins_fill" (Multiple Fill Fields introduced in Tiki 9.0) which should start with a number: {CODE()}{JQ()} nosubmitItemForm1 = false; $('#editItemForm1').submit(function() { var valeurs = $('#ins_fill').val(); var listeValeurs = valeurs.split("\n"); var $errorCount = 0; var $errorDots = "<span id='errorfill' class='errorfill' >"; var $validPattern = /(^\s*\d+\s*,)|(^\s*$)/; for (var i in listeValeurs) { if ( listeValeurs[i].search($validPattern) != -1 ) { $errorDots += "<br />"; } else { $errorCount++; $errorDots += "× <br />"; } } $('#errorfill').remove(); $('#ins_fill').css({'width':'99%','border':'#d5d1cf inset 2px','color':'#000000;','background-color':'#D2D9E3'}); if( $errorCount == 0 ) { // C'est bon nosubmitItemForm1 = false; } else { alert("ERREUR" + "\n" + "La bonne syntaxe est : nombre,critère"+"\n"+"Nombre de lignes fautives : " + $errorCount); nosubmitItemForm1 = true; $('#ins_fill').before($errorDots+"</span>").css({'overflow-x':'scroll','width':'90%','border':'2px solid #CD0A0A','color':'#CD0A0A;','background-color':'#FEF1EC'}); $('#errorfill').css({'float':'left'}); } return false; });{JQ}{CODE}