/**
 * TKD Admin Controller Wrapper Class.
 *
 * @package		TKDAdmin Controller
 * @author		Muhammad Uzair Khan (Muhammad.Uzair@tradekey.com)
 * @version		2.0 -- Robust , Advanced And More Frustating... 
 * @since		Version 1.0 2013
 * @comments	Please think of it as fun :P AND ENJOY
 */
class MY_Controller_Admin extends CI_Controller {
	private static $instance;
	/**
	 * Constructor
	 */
	protected $layout_data = array();
	protected $layout;
	// FOR Add methods, to prevent_return on Success
	public $prevent_return_on_success = false;
	public $dt_params = array();
	public function __construct() {
		global $config;
		parent::__construct();
		
		$config = $this->config->config;
		$this->session_data = $this->layout_data['session_data'] = $this->session->userdata('logged_in');
		$this->user_data = $this->session->userdata("logged_in");
		$this->chk_currency() ;
		$config['js_config']['ci_class'] = $config['ci_class'] = $this->router->class;
		$config['js_config']['ci_method'] = $config['ci_method'] = $this->router->method;
		$config['js_config']['ci_index_page'] = $config['ci_index_page'] = $config['ci_class'] ."_". $config['ci_method'];
		
		$this->layout_data['query_string'] = $_SERVER['QUERY_STRING'];
		$this->layout_data['additional_tools'] = array();
		
		if(!isset( $this->dt_params['paginate'] ))
			$this->dt_params['paginate'] = array();
		
		$this->dt_params['paginate']['class'] = $config['ci_class'];
		$this->dt_params['paginate']['uri'] = "paginate";
		$this->dt_params['paginate']['update_status_uri'] = "update_status";
		$this->layout_data['template_config'] = array ( 
			'show_toolbar' => true ,
		);
		$config['js_config']['paginate'] = $this->dt_params['paginate'];
	}
	public function index($dt_params = array())
	{
		global $config;
		
		$class_name = $this->router->class;
		$model_name = "model_".$class_name;
		$model_obj = $this->$model_name ;
		//$pg_config['order_field'] = $model_obj->get_order_field_name();
		$this->layout_data['bread_crumbs'] = array(
												array(
													"home/"=>"Home" , 
													$class_name => humanize($class_name)
												)
											);
		$this->register_plugins( array(						
										"jquery-ui",
										"bootstrap",
										"bootstrap-hover-dropdown",
										"jquery-slimscroll",
										"uniform",
										"bootstrap-switch",
										"bootstrap-datepicker",
										"boots",
										"font-awesome",
										"simple-line-icons" ,
										"select2",
										"datatables",
										"bootbox",
										"bootstrap-toastr",
								));
		$this->add_script("pages/tasks.css");
		$this->add_script(array("table-ajax.js" , "datatable.js") , "js");
		$data['page_title_min'] = "Management";
		$data['page_title'] = $class_name;
		$data['class_name'] = $class_name;
		$data['model_name'] = $model_name;
		$data['model_obj'] = $model_obj;
		$data['model_fields'] = $model_obj->get_fields();
		$data['dt_params'] = $this->dt_params ;
		$data['model'] = "$model_name";
		$this->before_index_render($data);
		$this->load_view("datatable" , $data );
	}
	public function paginate($dt_params = array())
	{
		global $config;
		$params = array();
		$pg_request = $_POST;
		$class_name = $this->router->class;
		$model_name = "model_".$class_name;
		$model_obj = $this->$model_name ;
		$params = $model_obj->pagination_params;
		
		$sort_col = $pg_request['order'][0]['column'] ;
		if($sort_col!==null)
		{
			$sort_type = $pg_request['order'][0]['dir'] ;
			$params['order'] = $sort_col ." ".$sort_type;
		}
		$length = intval($pg_request['length']);
		$model_obj->_per_page = $length ? $length : $model_obj->_per_page;
		
		$records = $model_obj->pagination_query($params);
		// $dt_params['order_field'] = $model_obj->get_order_field_name();
		if(is_array($records['data']))
			$data = $this->prepare_datatable($records['data']);
		$dt_record = array();
		$dt_record["data"] = $data; 
		$dt_record["draw"] = $pg_request["draw"]; 
		$dt_record["recordsTotal"] = $records["count"]; 
		$dt_record["recordsFiltered"] = $records["count"]; 
		echo json_encode($dt_record); 
		exit();
		
	}
	public function get_mysqli() { 
	$db = (array)get_instance()->db;
	return mysqli_connect('localhost', $db['username'], $db['password'], $db['database']);
	}
	public function prepare_datatable($record,$dt_params=array()) {
		
		global $config;
		$class = $this->router->class ;
		
		$model_name = "model_".$class;
		$model_obj = $this->$model_name ;
		$model_fields = $model_obj->get_fields();
		$model_pk = $model_obj->get_pk();
		
		if(!array_filled($dt_params))
			$dt_params = $this->dt_params;
		// If Record is an array. - Avoid annoying foreach warnings
		if(is_array($record))
		{
			$dt_row = array();
			// Start Record Parsing .... Watt
			foreach ($record as $row_key => $row) 
			{
				$table_data = array();
				$dt_row[ $row_key ] = array() ;
				$field_key = 0 ;
				// Prepare Data Fields
				foreach ($row as $field => $value) {
					// Dont need to show ordering field in DT
					if(!trim($field) || $field==$model_obj->get_order_field_name)
						continue;
					
					$value = mysqli_real_escape_string($this->get_mysqli(),$value);
					$field_attr = $model_fields[ $field ];
					$field_type = $field_attr['type_dt'] ? $field_attr['type_dt'] : $field_attr['type'] ;
					//  IF Field is PK, generate checkbox for MULTIPLE ROW SELECTION
					if($model_pk == $field)
					{
						// Do PK related types
						$itemId = intval($value) ;
						$dt_row[ $row_key ][ $field_key ] = '' ;
						$field_key++ ;
					}
					switch( $field_type )
					{
						case 'text':
						case 'textarea':
						case 'label':
						case 'label_custom':
						case 'editor':
							$value = html_entity_decode(strip_tags($value));
							$value = truncate($value,256);
							# code...
							break;
						
						case 'image':
							$image_url = $value ? $config['base_url'].$value : $config['image_not_found'] ;
							$value = ' ' ;
							break;
						
						case 'switch':
							$list_data = $field_attr['list_data'];
							if(!array_filled($list_data))
							{
								$list_data = array( 
	                                        STATUS_ACTIVE =>  "Active"  ,
	                                        STATUS_INACTIVE => "Inactive" ,  
	                                    ) ;
							}
							$value = $list_data[$value] ;
							break;
						case 'dropdown':
							$list_data = $field_attr['list_data'];
							if(!array_filled($list_data))
							{
								$list_data_key = $field_attr['list_data_key'] ? $field_attr['list_data_key'] : $field ;
								$list_data = $this->_list_data[$list_data_key];
							}
							$value = $list_data[$value] ;
							break;
						
						case 'hidden':
							continue;
							break;
					}
					$dt_row[ $row_key ][ $field_key ] = $value ;
					$field_key++ ;
				} // End - Data Fields Prep
				// DELETE Button
				if($dt_params['action']['show_delete'])
					$delete_button = '';
				
				// EDIT Button
				if($dt_params['action']['show_edit'])
					$edit_button = '';
				
				// ORDER FIELD- HIDDEN
				if($dt_params['action']['order_field'])
					$order_field = '';
				
				// VIEW BUTTON
				if($dt_params['action']['show_view'])
					$edit_button = '';
				
				$extra_buttons = '' ;
				
				// If Controller Has EXTRA BUTTONS defined , render them as well.
				if(array_filled($dt_params['action']['extra']))
				{
					foreach ($dt_params['action']['extra'] as $btn) {
						$extra_buttons .= sprintf($btn,$itemId) ;
					}
				} // End - IF extra_buttons
				if(!$dt_params['action']['hide'])
					$dt_row[ $row_key ][ $field_key ] = $edit_button . $delete_button . $extra_buttons . $order_field ;
			} // End Record Parsing...
		} // End if - Record is array
		return $dt_row;
	}
	public function configure_add_page()
	{
		$this->add_script(array( "jquery.validate.min.js") , "js" );
		$this->register_plugins(array(						
									"jquery-ui",
									"bootstrap",
									"bootstrap-hover-dropdown",
									"jquery-slimscroll",
									"uniform",
									"boots",
									"font-awesome",
									"simple-line-icons" ,
									"select2",
									"bootbox",
									"bootstrap-toastr",									
								));
		# code...
	}
	public function add($id=0 , $data = array()) {
		if($_POST)
		{
			//debug($_POST);
			//debug($id);exit;
		}
		global $config;
		$id = intval($id);
		$this->configure_add_page();
		$class_name = $this->router->class;
		$model_name = 'model_'.$class_name ;
		$model_obj = $this->$model_name ;
		$form_fields = $model_obj->get_fields();
		
		// Prepare models used in this action
		$model_array = array();
		$model_array = $this->_extra_models_add;
		$model_array[] = $model_name;
		
		$this->_validation_models_add[] = $model_name;
		
		$pk = $model_obj->get_pk() ;
		if($id)
		{
			$params['where'][$pk] = $id;
			$this->form_data[$class_name] = $this->$model_name->find_one($params);
			
			// Load relation fields data
			$this->form_data['relation_data'] = $this->$model_name->get_relation_data($id);
			if(count($this->form_data[$class_name])==0)
			{
				redirect($this->admin_path."?msgtype=error&msg=404+-+Record+not+found.", 'refresh');
				exit();
			}
		}
	
		//$pg_config['order_field'] = $model_obj->get_order_field_name();
		$this->layout_data['bread_crumbs'] = array(
												array(
													"home/"=>"Home" , 
													$class_name => humanize($class_name),
													$class_name."/add/" => "Add ".humanize($class_name),
												)
											);
		$user_data = $this->input->post(NULL, true);
		$data['form_data'] = $this->form_data;
		$data['user_input'] = $user_data['login'];
		if($_POST)
		{
			//debug($_POST);
			//debug($id);exit;
			//debug($_POST,1);
			if( $this->bulk_validate($this->_validation_models_add) )
			{
				// Validation Successful
				
				$user_data = $_POST[$class_name]  ;
			
				// Merge FILES field with POST DATA
				if( is_array($user_data) && is_array($_FILES[$class_name]['name']))
					$user_data = $user_data + $_FILES[$class_name]['name'] ;
				
				$this->$model_name->set_attributes($user_data);
				$insertId = $this->$model_name->save();
				if($insertId)
				{
					$this->$model_name->update_relations($insertId);
					$this->afterSave($insertId , $this->$model_name);
					// Prevent Return From Parent Add Method(current), 
					// since we need to perform operations in Child Class's Method
					if($this->prevent_return_on_success)
						return $insertId;
					$this->add_redirect_success($insertId);
				}
				else
				{
					redirect($this->admin_path."?msgtype=error&msg=Couldnt Save Data.", 'refresh');
			 		exit();
				}
			}
			else
			{
				$data['error'] = validation_errors();
			}
			
		}
		
		$data['page_title_min'] = "Management";
		$data['page_title'] = $class_name;
		$data['class_name'] = $class_name;
		$data['model_name'] = $model_name;
		$data['model_obj'] = $model_obj;
		$data['form_fields'][$class_name] = $form_fields;
		$data['dt_params'] = $this->dt_params ;
		$data['id'] = $id; 
		$this->before_add_render($data);
		$this->load_view("_form", $data);
	}
	public function afterSave($insertId , $model)
	{
		return true ;
	}
	
	public function ajax_view($id=0) {
		 echo json_encode($this->get_view($id)) ;
	}
	public function get_view($id=0) {
		global $config;
		$result = array();
		$class_name = $this->router->class;
		$model_name = 'model_'.$class_name ;
		$model_obj = $this->$model_name ;
		$form_fields = $model_obj->get_fields();
		if($id)
		{
			$result['record'] = $this->$model_name->find_by_pk($id);
			$result['record'] = $this->$model_name->prepare_view_data($result['record']);
			if(!$result['record'] )
				$result['failure'] = "No Item Found";
				// Load relation fields data
			$relation_data = $this->$model_name->get_relation_data($id);
			if(array_filled($relation_data))
				$result['record']['relation_data'] = $relation_data;
		}
		else
		{
			$result['failure'] = "No Item Found";
		}
	
		return $result;
	}
	public function add_redirect_success($id)
	{
		switch($_POST['submit'])
		{
			case "SaveNEdit":
				$path = $this->admin_current.$id;
			break;
			case "SaveNNew":
				$path = $this->admin_current;
			break;
			default:
				$path = $this->admin_path;
			break;
		}
		redirect($path."?msgtype=success&msg=Record updated successfuly.", 'refresh');
		return $id;
	}
	/*
	* Default Action to Bulk Delete from admin
	*/
	public function delete_selected() {
		$id_array = explode(",", rtrim($_POST['params']['pk'],","));
		
		foreach ($id_array as $id) {
			$_POST['params']['pk'] = intval($id);
			if(intval($id))
				$this->delete();
		}
	}
	// BeforeRender Hook to manipulate Overrides... for Add Method
	public function before_add_render()
	{
		// To access from Child Class
		return true;
	}
	// BeforeRender Hook to manipulate Overrides... for INdex Method
	public function before_index_render(&$data)
	{
		// To access from Child Class
		return true;
	}
	/*
	* Default Action to Delete
	*/
	public function delete() {
		$id = intval($_POST['params']['pk']);
		if($id){
			$model = $_POST['params']['model'];
			$model_obj = $this->{$model};
			$pk = $model_obj->get_pk();
			$status_field = $model_obj->get_status_field();
			$data[$status_field] = 2;
			
			if($this->router->class==$model){
				$this->db->where($pk, $id);
				$update = $this->db->update($model,$data); 
				if($update==true)
				echo "1";	
			}	
		}
		
	}
	/*
	* Default Action to Delete Permanently
	*/
	public function permanent_delete() {
		$id = intval($_POST['params']['pk']);
		if($id){
			$class_name = $this->router->class;
			$model_name = 'model_'.$class_name ;
			$model_obj = $this->$model_name ;
			return $model_obj->delete_by_pk($id);
		}
		
	}
	/*
	* Default Action to Update Record
	* Mostly to update Status
	*/
	public function update_status() {
		extract($_POST);
		if( array_filled($idList) && $model ){
			
			$updateVal = intval($updateVal);
			$model_obj = $this->{$model};
			$status_field = $model_obj->get_status_field();
			$pk = $model_obj->get_pk();
			if($status_field && $pk)
			{
				$record[$status_field] = $updateVal;
				$params['where_in'][$pk] = $idList;
				$ret['affected'] = $model_obj->update_model($params, $record) ;
				end_script( json_encode($ret) );
			}
		}
		
	}
	/*
	* Default Action to Update Record
	* Mostly to update Status
	*/
	public function update() {
		if(is_array($_POST['params']) && count($_POST['params'])){
			$model = $_POST['params']['model'];
			$pk = $_POST['params']['pk'];
			$val = $_POST['params']['val']==0?1:0;
			$field = $_POST['params']['field'];
			$data[$field] = $val;
			
			if($this->router->class==$model){
				$this->db->where($pk , $pk);
				$update = $this->db->update($model,$data); 
				if($update==true)echo 1;
				else echo 0;
			}	
		}
		
	}
	/*
	* Default Action to Reorder Objects. Requre DnD plugin in datatables
	*/
	public function reorder() {
		global $config;
		extract($_POST);
		$this->load->model(array($model));
		$effected = $this->$model->reorder_records($_POST) ;
		
		echo $effected;
		exit();
	}
	/*
	* Parse Records for Excel
	* $record MUST HAVE key : $records['data'], that  hold record
	*/
	public function parse_for_excel($records=array())
	{
		$data = $records['data'];
		if(array_filled($data))
		{
			if($data[0])
			{
				foreach ($data[0] as $heads => $value) {
					$records['headers'][] = $heads;
				}
			}
		}
		$records['heading'] = $records['heading'] ? $records['heading'] : $this->router->class;
		return $records;
	}
	/*
	* Default Admin Action to Export files to Excel
	* Export to Excel
	*/
	public function export_excel($params = array())
	{
		$model_name = "model_".$this->router->class;
		$this->load->model($model_name);
		$model_obj = $this->$model_name ;
		$model_obj->pagination_params ['limit'] = 1000000000;
		// Merge $params with child params
		$params += $model_obj->pagination_params ;
		$records = $model_obj->pagination_query($params);
		$data['records'] = $this->parse_for_excel($records);
		$data['filename'] = $this->router->class;
		$this->load_view("excel_export" , $data , false, false);
	}
}
?>
' ;
							break;
						
						case 'switch':
							$list_data = $field_attr['list_data'];
							if(!array_filled($list_data))
							{
								$list_data = array( 
	                                        STATUS_ACTIVE =>  "Active"  ,
	                                        STATUS_INACTIVE => "Inactive" ,  
	                                    ) ;
							}
							$value = $list_data[$value] ;
							break;
						case 'dropdown':
							$list_data = $field_attr['list_data'];
							if(!array_filled($list_data))
							{
								$list_data_key = $field_attr['list_data_key'] ? $field_attr['list_data_key'] : $field ;
								$list_data = $this->_list_data[$list_data_key];
							}
							$value = $list_data[$value] ;
							break;
						
						case 'hidden':
							continue;
							break;
					}
					$dt_row[ $row_key ][ $field_key ] = $value ;
					$field_key++ ;
				} // End - Data Fields Prep
				// DELETE Button
				if($dt_params['action']['show_delete'])
					$delete_button = '';
				
				// EDIT Button
				if($dt_params['action']['show_edit'])
					$edit_button = '';
				
				// ORDER FIELD- HIDDEN
				if($dt_params['action']['order_field'])
					$order_field = '';
				
				// VIEW BUTTON
				if($dt_params['action']['show_view'])
					$edit_button = '';
				
				$extra_buttons = '' ;
				
				// If Controller Has EXTRA BUTTONS defined , render them as well.
				if(array_filled($dt_params['action']['extra']))
				{
					foreach ($dt_params['action']['extra'] as $btn) {
						$extra_buttons .= sprintf($btn,$itemId) ;
					}
				} // End - IF extra_buttons
				if(!$dt_params['action']['hide'])
					$dt_row[ $row_key ][ $field_key ] = $edit_button . $delete_button . $extra_buttons . $order_field ;
			} // End Record Parsing...
		} // End if - Record is array
		return $dt_row;
	}
	public function configure_add_page()
	{
		$this->add_script(array( "jquery.validate.min.js") , "js" );
		$this->register_plugins(array(						
									"jquery-ui",
									"bootstrap",
									"bootstrap-hover-dropdown",
									"jquery-slimscroll",
									"uniform",
									"boots",
									"font-awesome",
									"simple-line-icons" ,
									"select2",
									"bootbox",
									"bootstrap-toastr",									
								));
		# code...
	}
	public function add($id=0 , $data = array()) {
		if($_POST)
		{
			//debug($_POST);
			//debug($id);exit;
		}
		global $config;
		$id = intval($id);
		$this->configure_add_page();
		$class_name = $this->router->class;
		$model_name = 'model_'.$class_name ;
		$model_obj = $this->$model_name ;
		$form_fields = $model_obj->get_fields();
		
		// Prepare models used in this action
		$model_array = array();
		$model_array = $this->_extra_models_add;
		$model_array[] = $model_name;
		
		$this->_validation_models_add[] = $model_name;
		
		$pk = $model_obj->get_pk() ;
		if($id)
		{
			$params['where'][$pk] = $id;
			$this->form_data[$class_name] = $this->$model_name->find_one($params);
			
			// Load relation fields data
			$this->form_data['relation_data'] = $this->$model_name->get_relation_data($id);
			if(count($this->form_data[$class_name])==0)
			{
				redirect($this->admin_path."?msgtype=error&msg=404+-+Record+not+found.", 'refresh');
				exit();
			}
		}
	
		//$pg_config['order_field'] = $model_obj->get_order_field_name();
		$this->layout_data['bread_crumbs'] = array(
												array(
													"home/"=>"Home" , 
													$class_name => humanize($class_name),
													$class_name."/add/" => "Add ".humanize($class_name),
												)
											);
		$user_data = $this->input->post(NULL, true);
		$data['form_data'] = $this->form_data;
		$data['user_input'] = $user_data['login'];
		if($_POST)
		{
			//debug($_POST);
			//debug($id);exit;
			//debug($_POST,1);
			if( $this->bulk_validate($this->_validation_models_add) )
			{
				// Validation Successful
				
				$user_data = $_POST[$class_name]  ;
			
				// Merge FILES field with POST DATA
				if( is_array($user_data) && is_array($_FILES[$class_name]['name']))
					$user_data = $user_data + $_FILES[$class_name]['name'] ;
				
				$this->$model_name->set_attributes($user_data);
				$insertId = $this->$model_name->save();
				if($insertId)
				{
					$this->$model_name->update_relations($insertId);
					$this->afterSave($insertId , $this->$model_name);
					// Prevent Return From Parent Add Method(current), 
					// since we need to perform operations in Child Class's Method
					if($this->prevent_return_on_success)
						return $insertId;
					$this->add_redirect_success($insertId);
				}
				else
				{
					redirect($this->admin_path."?msgtype=error&msg=Couldnt Save Data.", 'refresh');
			 		exit();
				}
			}
			else
			{
				$data['error'] = validation_errors();
			}
			
		}
		
		$data['page_title_min'] = "Management";
		$data['page_title'] = $class_name;
		$data['class_name'] = $class_name;
		$data['model_name'] = $model_name;
		$data['model_obj'] = $model_obj;
		$data['form_fields'][$class_name] = $form_fields;
		$data['dt_params'] = $this->dt_params ;
		$data['id'] = $id; 
		$this->before_add_render($data);
		$this->load_view("_form", $data);
	}
	public function afterSave($insertId , $model)
	{
		return true ;
	}
	
	public function ajax_view($id=0) {
		 echo json_encode($this->get_view($id)) ;
	}
	public function get_view($id=0) {
		global $config;
		$result = array();
		$class_name = $this->router->class;
		$model_name = 'model_'.$class_name ;
		$model_obj = $this->$model_name ;
		$form_fields = $model_obj->get_fields();
		if($id)
		{
			$result['record'] = $this->$model_name->find_by_pk($id);
			$result['record'] = $this->$model_name->prepare_view_data($result['record']);
			if(!$result['record'] )
				$result['failure'] = "No Item Found";
				// Load relation fields data
			$relation_data = $this->$model_name->get_relation_data($id);
			if(array_filled($relation_data))
				$result['record']['relation_data'] = $relation_data;
		}
		else
		{
			$result['failure'] = "No Item Found";
		}
	
		return $result;
	}
	public function add_redirect_success($id)
	{
		switch($_POST['submit'])
		{
			case "SaveNEdit":
				$path = $this->admin_current.$id;
			break;
			case "SaveNNew":
				$path = $this->admin_current;
			break;
			default:
				$path = $this->admin_path;
			break;
		}
		redirect($path."?msgtype=success&msg=Record updated successfuly.", 'refresh');
		return $id;
	}
	/*
	* Default Action to Bulk Delete from admin
	*/
	public function delete_selected() {
		$id_array = explode(",", rtrim($_POST['params']['pk'],","));
		
		foreach ($id_array as $id) {
			$_POST['params']['pk'] = intval($id);
			if(intval($id))
				$this->delete();
		}
	}
	// BeforeRender Hook to manipulate Overrides... for Add Method
	public function before_add_render()
	{
		// To access from Child Class
		return true;
	}
	// BeforeRender Hook to manipulate Overrides... for INdex Method
	public function before_index_render(&$data)
	{
		// To access from Child Class
		return true;
	}
	/*
	* Default Action to Delete
	*/
	public function delete() {
		$id = intval($_POST['params']['pk']);
		if($id){
			$model = $_POST['params']['model'];
			$model_obj = $this->{$model};
			$pk = $model_obj->get_pk();
			$status_field = $model_obj->get_status_field();
			$data[$status_field] = 2;
			
			if($this->router->class==$model){
				$this->db->where($pk, $id);
				$update = $this->db->update($model,$data); 
				if($update==true)
				echo "1";	
			}	
		}
		
	}
	/*
	* Default Action to Delete Permanently
	*/
	public function permanent_delete() {
		$id = intval($_POST['params']['pk']);
		if($id){
			$class_name = $this->router->class;
			$model_name = 'model_'.$class_name ;
			$model_obj = $this->$model_name ;
			return $model_obj->delete_by_pk($id);
		}
		
	}
	/*
	* Default Action to Update Record
	* Mostly to update Status
	*/
	public function update_status() {
		extract($_POST);
		if( array_filled($idList) && $model ){
			
			$updateVal = intval($updateVal);
			$model_obj = $this->{$model};
			$status_field = $model_obj->get_status_field();
			$pk = $model_obj->get_pk();
			if($status_field && $pk)
			{
				$record[$status_field] = $updateVal;
				$params['where_in'][$pk] = $idList;
				$ret['affected'] = $model_obj->update_model($params, $record) ;
				end_script( json_encode($ret) );
			}
		}
		
	}
	/*
	* Default Action to Update Record
	* Mostly to update Status
	*/
	public function update() {
		if(is_array($_POST['params']) && count($_POST['params'])){
			$model = $_POST['params']['model'];
			$pk = $_POST['params']['pk'];
			$val = $_POST['params']['val']==0?1:0;
			$field = $_POST['params']['field'];
			$data[$field] = $val;
			
			if($this->router->class==$model){
				$this->db->where($pk , $pk);
				$update = $this->db->update($model,$data); 
				if($update==true)echo 1;
				else echo 0;
			}	
		}
		
	}
	/*
	* Default Action to Reorder Objects. Requre DnD plugin in datatables
	*/
	public function reorder() {
		global $config;
		extract($_POST);
		$this->load->model(array($model));
		$effected = $this->$model->reorder_records($_POST) ;
		
		echo $effected;
		exit();
	}
	/*
	* Parse Records for Excel
	* $record MUST HAVE key : $records['data'], that  hold record
	*/
	public function parse_for_excel($records=array())
	{
		$data = $records['data'];
		if(array_filled($data))
		{
			if($data[0])
			{
				foreach ($data[0] as $heads => $value) {
					$records['headers'][] = $heads;
				}
			}
		}
		$records['heading'] = $records['heading'] ? $records['heading'] : $this->router->class;
		return $records;
	}
	/*
	* Default Admin Action to Export files to Excel
	* Export to Excel
	*/
	public function export_excel($params = array())
	{
		$model_name = "model_".$this->router->class;
		$this->load->model($model_name);
		$model_obj = $this->$model_name ;
		$model_obj->pagination_params ['limit'] = 1000000000;
		// Merge $params with child params
		$params += $model_obj->pagination_params ;
		$records = $model_obj->pagination_query($params);
		$data['records'] = $this->parse_for_excel($records);
		$data['filename'] = $this->router->class;
		$this->load_view("excel_export" , $data , false, false);
	}
}
?>