Search

Oct 14, 2015

Jquery Validate

Get plugin and document
http://jqueryvalidation.org/documentation/

File javascript


var _ids = {
    formAddUserInAdminPage:'#add_user_admin_form',
    saveAddUserInAdminPageButton: "#addUserSubmitButton",
    getUserName: "#userNameAddUserForm",
    checkExistsUser: "#checkExistsUser",
    uploadAvatarId : "#uploadAvatarId",
    tmpAvaImage: "#tmpAvaImage",
    clickAddUserButton: "#clickAddUserButton"
};

var editForm = {
    clickUserName: ".clickUserName",
    firstName:'input[name=firstNameEdit]',
    lastName: 'input[name=lastNameEdit]',
    username: 'input[name=usernameEdit]',
    email: 'input[name=emailEdit]',
    phone: 'input[name=phoneEdit]',
    female: 'input[name=genderEdit][data-gender=0]',
    male: 'input[name=genderEdit][data-gender=1]',
    clickUploadButton: "#clickUploadAvaEditForm",
    uploadAvatarId : "#uploadAvatarEdit",
    tmpAvaImage: "#tmpAvaImageEdit"
};

var addForm = {
    firstName:'input[name=firstName]',
    lastName: 'input[name=lastName]',
    username: 'input[name=username]',
    password: 'input[name=password]',
    re_password: 'input[name=re_password]',
    email: 'input[name=email]',
    phone: 'input[name=phone]',
    clickUploadButton: "#clickUploadAvaAddUserForm",
    uploadAvatarId : "#uploadAvatar",
    tmpAvaImage: "#tmpAvaImage"
};

var infoFormEvent = {
    init: function () {
        this.validationFormAddUserInAdminPage();
        this.saveAddUserInAdminPageButtonClick();
        this.clickEditUserName();
    },
    validationFormAddUserInAdminPage: function () {
        $(_ids.formAddUserInAdminPage).validate({
            rules: {
                firstName: {required: true},
                lastName: {required: true},
                username: {required: true},
                email: {required: true,email: true},
                password: { required: true },
                re_password: { required: true, equalTo: '#firstPassword' },
                phone: { required: true, number: true},
                existsUser:  {equalTo: '#valueExistsUser'},
                uploadAvatar: {required: true}
            },
            messages: {
                firstName: {required: "First name is required."},
                lastName: {required: "Last name is required."},
                username: {required: "First name is required."},
                password: {required: "Password is required."},
                re_password: {required: "Re-password is required."},
                phone : { required: "Phone is required.", number: "Not number"},
                email: {required: "Email is required."},
                existsUser:  {equalTo: "Username of Email is exists."},
                uploadAvatar: {required: "Avatar is required."}
            }            
        });
    },
    saveAddUserInAdminPageButtonClick: function () {
        // Username input is changed (add user form)
        $(_ids.getUserName).change(function(){
            var username = $(addForm.username).val();
            var email = $(addForm.email).val();
            infoFormEvent.checkExistsUser(username, email);
        });
        // Email input is changed (add user form)
        $(addForm.email).change(function(){
            var username = $(addForm.username).val();
            var email = $(addForm.email).val();
            infoFormEvent.checkExistsUser(username, email);
        });
        // Click upload Avatar button (add user form)
        $(addForm.clickUploadButton).click(function(){
            $(addForm.uploadAvatarId).trigger("click");
        });
        // Click upload Avatar button (Edit user form)
        $(editForm.clickUploadButton).click(function(){
            $(editForm.uploadAvatarId).trigger("click");
        });
        // Get uploaded Avatar (add user form)
        $(addForm.uploadAvatarId).change(function(e){
            var srcAva = URL.createObjectURL(e.target.files[0]);
            $(addForm.tmpAvaImage).attr("src",srcAva);
        });
        // Click add User button (admin page)
        $(_ids.clickAddUserButton).click(function(){
            infoFormEvent.resetAddUserForm();
        });
        // Click Submit Button (add user form)
        $(_ids.saveAddUserInAdminPageButton).on("click", function () {
            if ($(_ids.formAddUserInAdminPage).valid()) {
               $(_ids.formAddUserInAdminPage).submit();
            }
        });
    },
    checkExistsUser: function (username, email) {
        $.ajax({
            url: getBaseUrl() +'/admin/default/existsUser',
            type: 'post',
            data:{
                'username':username,
                'email':email
            },
            cache: false,
            success: function(data) {
                var checkExists = (data === "true");
                infoFormEvent.setExistsUser(checkExists);
                return data;
            }
        });
    },
    setExistsUser: function (check) {
        $(_ids.checkExistsUser).val(check);
        $(_ids.formAddUserInAdminPage).valid();
    },
    clickEditUserName: function(){
        // Click username link
        $(editForm.clickUserName).click(function(){
            // Get User Id
            var userId = $(this).attr('data-user-id');
            // Load AJAX User Data
            infoFormEvent.loadAjaxByUserId(userId);
        });
    },
    loadAjaxByUserId: function(uId) {
        $.ajax({
            type: "post",
            url: getBaseUrl() +'/admin/default/getUser',
            data: { 'id' : uId },
            cache: false,
            success: function(data){
                var dataObj = $.parseJSON(data);
                infoFormEvent.pushUserToEditForm(dataObj);
            }
        });
    },
    pushUserToEditForm: function(data) {
        try {
            $(editForm.firstName).val(data.firstName);
            $(editForm.lastName).val(data.lastName);
            $(editForm.username).val(data.username);
            $(editForm.email).val(data.email);
            $(editForm.phone).val(data.phone);

            if (data.gender === "1") {
                $(editForm.male).attr("checked","checked");
                $(editForm.female).removeAttr("checked");
            } else {
                $(editForm.male).removeAttr("checked");
                $(editForm.female).attr("checked","checked");
            }

            var avaSrc = (data.avatarPath && data.avatarPath != "") ? '/upload/avatars/'+data.avatarPath : "/images/defaultUser.png";
            $(editForm.tmpAvaImage).attr("src", avaSrc);
        } catch (err) {
            console.log(err);
        }
    },
    resetAddUserForm: function(){
        $(addForm.firstName).val("");
        $(addForm.lastName).val("");
        $(addForm.username).val("");
        $(addForm.password).val("");
        $(addForm.re_password).val("");
        $(addForm.email).val("");
        $(addForm.phone).val("");
        $(addForm.tmpAvaImage).attr("src", "/images/defaultUser.png");
        var validator = $(_ids.formAddUserInAdminPage).validate();
        validator.resetForm();
    }
};

$(document).ready(function () {
    "use strict";
    infoFormEvent.init();
});

Oct 12, 2015

Config virtualHost proxy in apache WAMP

In config/httpd.conf, recomment httpd-vhotss.conf
# Virtual hosts
Include conf/extra/httpd-vhosts.conf

In hosts file
127.0.0.1       localhost
127.0.0.1 mentor.vn

In config/extra/httpd-vhosts.conf, add codes:
Example: mentor.vn => localhost/mentor


NameVirtualHost *:80
<VirtualHost mentor.vn:80>
    ServerAdmin mentor.vn
    DirectoryIndex index.php
 DocumentRoot "C:\wamp\www\mentor" 
    ServerName mentor.vn
    ErrorLog "logs/mentor.com-error.log"
    CustomLog "logs/mentor.com-access.log" common 
  <Directory "C:\wamp\www\mentor">
    Options Indexes FollowSymlinks 
    AllowOverride all
    Order Allow,Deny
    Allow from all
 </Directory>
</VirtualHost>


CONFIG - UBUNTU

/etc/apache2/sites-available/000-default.config

<VirtualHost *:80>
 ServerAdmin webmaster@localhost
 DocumentRoot /var/www/html
 ServerName 127.0.1.1

 ErrorLog ${APACHE_LOG_DIR}/error.log
 CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>


/etc/apache2/sites-available/testhang.conf

<VirtualHost www.testhang.com:80>
 ServerAdmin www.testhang.com
 DocumentRoot /var/www/html/testhang
 ServerName www.testhang.com

 <Directory /var/www/html/testhang>
     Allow from all
     Options Indexes FollowSymLinks MultiViews
     AllowOverride All
     Order Allow,Deny
 </Directory>

 ErrorLog ${APACHE_LOG_DIR}/testhang-log.log
 CustomLog ${APACHE_LOG_DIR}/testhang-access.log combined

</VirtualHost>


/etc/hosts


127.0.0.1 localhost
127.0.1.1 ubuntu

127.0.1.1 www.testhang.com

# The following lines are desirable for IPv6 capable hosts
::1     ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters