MMCT TEAM
Server IP : 103.191.208.50  /  Your IP : 216.73.216.53
Web Server : LiteSpeed
System : Linux orion.herosite.pro 4.18.0-553.53.1.lve.el8.x86_64 #1 SMP Wed May 28 17:01:02 UTC 2025 x86_64
User : celkcksm ( 1031)
PHP Version : 7.4.33
Disable Function : show_source, system, shell_exec, passthru, popen, exec
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0755) :  /home/celkcksm/ecampus.ncriptech.com/application/models/hrm/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : /home/celkcksm/ecampus.ncriptech.com/application/models/hrm/Attendance_model.php
<?php defined('BASEPATH') OR exit('No direct script access allowed');


/**
 * 
 */
class Attendance_model extends BaseModel
{
    function __constuct(){
        parent::__construct(); 
    }
    
    public function store_attendance($data,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance';
        return $this->store($data,FALSE,$return_query);
    }

    public function update_attendance($data,$param,$batch=FALSE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance';
        return $this->modify($data,$param,$batch,$return_query);
    }

    public function delete_attendance($param,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance';
        return $this->remove($param,0,$return_query);
    }

    public function get_attendance($param=null,$single_row=TRUE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance';
        if($single_row==TRUE){
            return $this->get_one($param,'',$return_query);
        }else if($single_row==FALSE){
            return $this->get_many($param,null,null,$return_query);
        }       
    }

    public function get_total_attendance($param,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance';
        return $this->get_total_count($param,NULL,NULL,$return_query);
    }


    public function _get_total_attendance($param,$or_param=null,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance';
        return $this->_get_total_count($param,$or_param,NULL,$return_query);
    }


    public function get_last_attendance($param,$or_param=null,$order_by,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance';

        if($or_param==null){
            return $this->get_last($param,$order_by,$return_query);
        }else{
            return $this->_get_last($param,$or_param,$order_by,$return_query);
        }
        
    }




    //Leave Attendance Change Request

    public function store_attendance_change($data,$batch=FALSE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_changes';
        return $this->store($data,$batch,$return_query);
    }


    public function update_attendance_change($data,$param,$batch=FALSE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_changes';
        return $this->modify($data,$param,$batch,$return_query);
    }


    public function delete_attendance_change($param,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_changes';
        return $this->remove($param,0,$return_query);
    }

    public function get_attendance_change($param=null,$single_row=TRUE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_changes';
        if($single_row==TRUE){
            return $this->get_one($param,'',$return_query);
        }else if($single_row==FALSE){
            return $this->get_many($param,null,null,$return_query);
        }       
    }


    //Leave Attendance Change Request


    //Attendance Scheme

    public function store_attendance_scheme($data,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_scheme';
        return $this->store($data,FALSE,$return_query);
    }


    public function update_attendance_scheme($data,$param,$batch=FALSE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_scheme';
        return $this->modify($data,$param,$batch,$return_query);
    }


    public function delete_attendance_scheme($param,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_scheme';
        return $this->remove($param,0,$return_query);
    }

    public function get_attendance_scheme($param=null,$single_row=TRUE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_scheme';
        if($single_row==TRUE){
            return $this->get_one($param,'',$return_query);
        }else if($single_row==FALSE){
            return $this->get_many($param,null,null,$return_query);
        }       
    }


    public function _get_attendance_scheme($post=array(),$param=array(),$count=FALSE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->_db->select('institute_hrm_attendance_scheme.*');

        $i = 0;


        $this->_db->where('att_scheme_inst_id',$param['att_scheme_inst_id']);

        if(isset($param['column_search'])){
            foreach ($param['column_search'] as $item)
            {
                if(isset($post['search']['value']) && $post['search']['value'])
                {
                    
                    if($i===0)
                    {
                        $this->_db->group_start();
                        $this->_db->like($item, $post['search']['value']);
                    }
                    else
                    {
                        $this->_db->or_like($item, $post['search']['value']);
                    }

                    if(count($param['column_search']) - 1 == $i)
                        $this->_db->group_end();
                }
                
                $i++;
            }
        }

            
        if(isset($post['order']))
        {
            $column_order=$param['column_order'];
            $this->_db->order_by($column_order[$post['order']['0']['column']], $post['order']['0']['dir']);
        } 
        else if(isset($param['order']))
        {
            $order = $param['order'];
            $this->_db->order_by(key($order), $order[key($order)]);
        }

        if($count==FALSE){
            if(isset($post['length']) && $post['length'] != -1){
                $this->_db->limit($post['length'],$post['start']);   
            }
            
            $query = $this->_db->get('institute_hrm_attendance_scheme');

            if($return_query==FALSE){
                return $query->result();
            }else if($return_query==TRUE){
                return $this->_db->last_query();
            }       
            
        }else if($count==TRUE){
            $query = $this->_db->get('institute_hrm_attendance_scheme');
            if($return_query==FALSE){
                return $query->num_rows();
            }else if($return_query==TRUE){
                return $this->_db->last_query();
            }           
        }
    }



    //Attendance Policy

    public function store_attendance_policy($data,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_policy';
        return $this->store($data,FALSE,$return_query);
    }


    public function update_attendance_policy($data,$param,$batch=FALSE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_policy';
        return $this->modify($data,$param,$batch,$return_query);
    }


    public function delete_attendance_policy($param,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_policy';
        return $this->remove($param,0,$return_query);
    }

    public function get_attendance_policy($param=null,$single_row=TRUE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->table='institute_hrm_attendance_policy';
        if($single_row==TRUE){
            return $this->get_one($param,'',$return_query);
        }else if($single_row==FALSE){
            return $this->get_many($param,null,null,$return_query);
        }       
    }


    public function _get_attendance_policy($post=array(),$param=array(),$count=FALSE,$db_group=null,$return_query=FALSE){
        $db_group=!empty($db_group)?$db_group:DB_GROUP;
        $this->_db=$this->load->database($db_group, TRUE);
        $this->_db->select('institute_hrm_attendance_policy.*');

        $i = 0;


        $this->_db->where('att_policy_inst_id',$param['att_policy_inst_id']);

        if(isset($param['column_search'])){
            foreach ($param['column_search'] as $item)
            {
                if(isset($post['search']['value']) && $post['search']['value'])
                {
                    
                    if($i===0)
                    {
                        $this->_db->group_start();
                        $this->_db->like($item, $post['search']['value']);
                    }
                    else
                    {
                        $this->_db->or_like($item, $post['search']['value']);
                    }

                    if(count($param['column_search']) - 1 == $i)
                        $this->_db->group_end();
                }
                
                $i++;
            }
        }

            
        if(isset($post['order']))
        {
            $column_order=$param['column_order'];
            $this->_db->order_by($column_order[$post['order']['0']['column']], $post['order']['0']['dir']);
        } 
        else if(isset($param['order']))
        {
            $order = $param['order'];
            $this->_db->order_by(key($order), $order[key($order)]);
        }

        if($count==FALSE){
            if(isset($post['length']) && $post['length'] != -1){
                $this->_db->limit($post['length'],$post['start']);   
            }
            
            $query = $this->_db->get('institute_hrm_attendance_policy');

            if($return_query==FALSE){
                return $query->result();
            }else if($return_query==TRUE){
                return $this->_db->last_query();
            }       
            
        }else if($count==TRUE){
            $query = $this->_db->get('institute_hrm_attendance_policy');
            if($return_query==FALSE){
                return $query->num_rows();
            }else if($return_query==TRUE){
                return $this->_db->last_query();
            }           
        }
    }

}

MMCT - 2023