Avatar of Coast Line
Coast Line
Flag for Canada asked on

Need jquery Validation help to make it wirth with jquery UI submission

Hi Experts I need your help in fixing up my jquery UI form submission validation to work with jquery Validation Plugin. Currently the Jquery UI code i am using for submission is the below:

submitUsers = function() {
    
    $('#tabs_users>#ui-tabs-2').on('click', '.submitusers', function() {
        var dataString = $("form").serialize();
        $.ajax({
            type: "POST",
            url: "save.cfm?mode=useraction" + '&submission=' + Math.random(),
            cache: false,
            data: dataString,
            success: function(result) {
                var i = result;
                $('#tabs_users>#ui-tabs-2').off('click', '.submitusers');
                if ($.trim(i) == 'Warning! Country with Same Name already Exists' || $.trim(i) == 'Warning! Code for the Entered Country Exists for another Country' || $.trim(i) == 'Warning! Code and Country already Exists') {
                    $("#AddCountry").html(result).addClass('text-warning');
                    $("#AddCountry").addClass('text-warning').fadeIn("slow");
                    setTimeout(function() {
                        $("#AddCountry").addClass('text-warning').fadeOut("slow");
                    }, 3000);
                } else if ($.trim(i) == 'Cool! Processed Successfully') {
                    $("#AddCountry").html(result).addClass('text-success');
                    $("#AddCountry").addClass('text-success').fadeIn("slow");
                    setTimeout(function() {
                        $("#AddCountry").addClass('text-success').fadeOut("slow");
                    }, 3000);
                } else {
                    $("#AddCountry").html(result).addClass('text-error');
                    $("#AddCountry").addClass('text-error').fadeIn("slow");
                    setTimeout(function() {
                        $("#AddCountry").addClass('text-error').fadeOut("slow");
                    }, 3000);
                }
            }
        });
    });
}

Open in new window


I want to make the validation to work with this, How can i add validation plugin to this.

My form has following fields

<form id="adduser" name="adduser">
<label>Username</label>
        <input type="text" id="username" class="input-block-level-inputfields" name="username" placeholder="Username">
        <label>Password</label>
        <input type="password" id="password" name="password" class="input-block-level-inputfields" placeholder="Password Please" />
        <label>Full Name</label>
        <input type="tel" name="fullname" id="fullname" class="input-block-level" placeholder="Your Complete Full Name" />
        <label>Password Hint</label>
        <input type="text" name="passwordhint" id="passwordhint" class="input-block-level-inputfields" placeholder="Provide Password Hint (optional)" />
        <label>Security Question</label>
        <input type="text" class="input-block-level" placeholder="Security Question" id="question" name="question" />
        <label>Answer</label>
        <input type="text" class="input-block-level" placeholder="Security Answer to the above Question" id="answer" name="answer" />
        <label>Email Address</label>
        <input type="text" name="email" id="email" placeholder="Email Address" class="input-block-level" />
        <label>Role</label>
        <select name="rolesection" id="rolesection" class="input-block-level-inputfields">
        	<option value="1">Admin</option>
            <option value="2">Staff</option>
            <option value="3">User</option>
        </select>
        <label>Status</label>
        <select name="confirmed" id="confirmed" class="input-block-level-inputfields">
        	<option value="1">Confirmed</option>
            <option value="2">Blocked</option>
        </select>
        <br />
        <input type="button" class="btn submitusers" name="sbtuser" id="sbtuser" value="Submit" onclick="javascript:submitUsers();">
</form>

Open in new window

jQueryJavaScriptJScript

Avatar of undefined
Last Comment
mcnute

8/22/2022 - Mon
darren-w-

Hi,

What have you tried so far?

Darren
Coast Line

ASKER
honestly few tricks but none worked so far and kept deleting after every failed try
darren-w-

Ok,
Using http://bassistance.de/jquery-plugins/jquery-plugin-validation/, you need to include the plugin
Attached the validation to the page:

$("#adduser").validate();

add a class to the form fields, so for email address:

<input type="text" class="required email" name="email" id="email" placeholder="Email Address" class="input-block-level" />

and that will validate this field, you will just need to disable the button then until the form is valid
I started with Experts Exchange in 2004 and it's been a mainstay of my professional computing life since. It helped me launch a career as a programmer / Oracle data analyst
William Peck
Coast Line

ASKER
Thanks, I was trying with this plugin, But my question is:

1. where i add this, when i am doing the on click event of the function or before

2. how can i stop its processing unless all errors has been cleared.
darren-w-

add it before,
on keyup call $("#adduser").valid() this will return T/F and then based on this enable/disable the submit button
Coast Line

ASKER
i want to have validation on submit of the Page, not on keyup. anyways, i am still looking for solution. Thanks anyways, when i do it, i will post the answer here
⚡ FREE TRIAL OFFER
Try out a week of full access for free.
Find out why thousands trust the EE community with their toughest problems.
darren-w-

ASKER CERTIFIED SOLUTION
mcnute

THIS SOLUTION ONLY AVAILABLE TO MEMBERS.
View this solution by signing up for a free trial.
Members can start a 7-Day free trial and enjoy unlimited access to the platform.
See Pricing Options
Start Free Trial
GET A PERSONALIZED SOLUTION
Ask your own question & get feedback from real experts
Find out why thousands trust the EE community with their toughest problems.
Coast Line

ASKER
Thanks, But it is going in both the commands, if and the lese too
untitled.GIF
mcnute

You're doing a validation in your ajax with code that's coming from the server side. So it is not possible to validate data which is processed by the server without submitting the form.

What you can do is to populate the form with the primary submitted values stored in your i variable and sent that back to the form when thir first if clause and or the else is true.

Or:

What would make more sense is to submit that form to the same page the form is on (without ajax involved) and on the server side redirect to a success page if data was alright, or just stay on the original form page and 'paste' original input values in the form, so the user doesn't have to input it again and display error messages accordingly.

Hope I got the point for you.

Good Luck anyways!
This is the best money I have ever spent. I cannot not tell you how many times these folks have saved my bacon. I learn so much from the contributors.
rwheeler23