Skip to main content

Joomla validate chrono forms using jquery

It is a common practice to use Chrono forms in our joomla site to setup various forms in the site, be it a contact us form, submit a ticket form, or whatever.

I have set the option "validate form" to "No" under chronoform settings in admin panel, and also preferred to not include any js or css files.

For validating the chrono forms, i prefer jquery. So first lets add jquery support in our joomla. It is quite simple:

1. Download jquery.js and jquery_min.js (1.4.2 version is enough) and place them in media/system/js folder of your joomla.

2. Edit libraries->joomla->html->html->behavior.php, and add the following function below the mootools() function:

function jQuery($debug = null)
    {
        static $loaded;

        global $mainframe;
        // Only load once
        if ($loaded) {
            return;
        }

        // If no debugging value is set, use the configuration setting
        if ($debug === null) {
            $config = &JFactory::getConfig();
            $debug = $config->getValue('config.debug');
        }

        $konkcheck = strpos (strtolower($_SERVER['HTTP_USER_AGENT']), "konqueror");

        if ($debug || $konkcheck) {
            JHTML::script('jquery.js', 'media/system/js/', false);
        } else {
            if($mainframe->isSite()) {

                JHTML::script('jquery.min.js', 'media/system/js/', false);
            }
            else
            {
                JHTML::script('mootools.js', 'media/system/js/', false);
            }
        }
        $loaded = true;
        return;
    }


3. Create a js file (noconflict.js) with just this content:
jQuery.noConflict();

and upload it in your site.... (probably in the media/system/js folder).

4. Add the jquery scripts in your joomla template index file:

$document    = &JFactory::getDocument();
$document->addScript($root_url.'media/system/js/jquery.js' );
$document->addScript($root_url.'media/system/js/noconflict.js' );

Now the jquery support is available to your joomla (through out the site).

I have download the jquery validation library file (jquery_validate.js) and put it in components/com_chronocontact/js folder.

Now lets edit the components/com_chronocontact/chronocontact.html.php and write the code to validate our chronoform:

Find the line in the file (usually at the top) something like:

if((!empty($MyForm->formrow->name))&&($MyForm->formrow->published)){
        ?>

Below that, add the following code:

<!-- JS files and validation added by shashi -->
        <script type="text/javascript" src="<?php echo $CF_PATH; ?>components/com_chronocontact/js/jquery_validate.js"></script>
        <script type="text/javascript">
        jQuery(document).ready(function(){
        jQuery("#<?php echo "ChronoContact_".$MyForm->formrow->name; ?>").validate();
        });
        </script>

Thats it... we have dynamically added the jquery validation for any chronoform in our joomla site.

Finally, in the form code (under admin panel) of your chronoform, dont forget to add validation classes to the elements, like: class="required" for text fields, class="required email" for email field, and class="submit" for submit button.

Done :)

Comments

Popular posts from this blog

Retaining checkbox status of a form after submitting it

we will learn here how to post back or retain the value ( status ) of the checkbox. We will use php header redirection to post back the values to our main page where checkbox is present. We will call form page as first page and action or submitted page as second page. The form data will be received by second page and it is supposed to post back the form data back to form page by using query string through address bar. To keep the second page simple we will keep only the redirection part. Here we have excluded the part which takes care if the form passes its validation and execute the actual script (redirection part). Here is the code of our form with two checkboxes, pb-check.php <?php $t1=$_GET['t1']; $t2=$_GET['t2']; if($t1=="yes"){$t1v="checked";} else{$t1v=="";} if($t2=="yes"){$t2v="checked";} else{$t2v=="";} ?> HTML Form code: <form method="post" action="pb-chk.php"> <inp...

Identify the user's browser

Sometimes there arises a need to identify the user's browser. It is pretty easy to find browser with jquery. So if you have included jquery in your page, it takes a simple line to identify the browser:  if ($. browser . msie ) {} // IE if (($.browser.msie) && ($.browser.version == '6.0')) {} // IE6 if ($. browser . opera ) {} // opera if ($. browser . mozilla) {} // Firefox With the help of php, you can get the browser  details with the help of:  $_SERVER['HTTP_USER_AGENT']; Or you can even use the combined version of php and javascript. php + javascript code: <script type="text/javascript"> var string1 = "<?php echo $_SERVER['HTTP_USER_AGENT']; ?>"; // Browser string var myRegExp1 = /Firefox/; var matchPos1 = string1.search(myRegExp1); var myRegExp2 = /Chrome/; var matchPos2 = string1.search(myRegExp2); var myRegExp3 = /MSIE/; var matchPos3 = string1.search(myRegExp3); if(matchPos1 != -1) ...

Facebook connect using graph api

An example of using facebook graph api to authenticate users: Setup a new application in facebook apps and get the app id and secret. Now follow the steps: Remember to give the same url in the below code, as that of the app settings. <?php if( !isset($_GET['code'])) { ?> <a href="https://graph.facebook.com/oauth/authorize?client_id=xxxxxxxx&redirect_uri=http://xxxxxxxxxxxxxxxx/">Connect using Facebook</a> <?php } $code = trim($_GET['code']); if(isset($_GET['code'])) $token = file_get_contents("https://graph.facebook.com/oauth/access_token?client_id=xxxxxxxx&redirect_uri=http://xxxxxxxxxxxxxxx&client_secret=xxxxxxxxxxxx&code=$code"); $token = explode("=", $token); if(isset($_GET['code'])) $user = json_decode(file_get_contents('https://graph.facebook.com/me?access_token='.$token[1]));  print_r($user); ?>