|
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/ |
Upload File : |
<?php defined('BASEPATH') OR exit('No direct script access allowed');
class Brand extends Public_Controller {
private $sort_product_by = NULL;
public function __construct() {
parent::__construct();
}
public function get($alias = NULL) {
if ($alias == NULL) {
show_404();
}
if ($alias == 'all') {
//get landingpage banner image, description and link
$this->db->select('brand_landingpage_description, brand_landingpage_image, brand_landingpage_link')->from('configuration')->where('id_configuration', 1);
$this->data['brand_landingpage'] = $this->db->get()->row();
//get brand parameters
$this->db->select('*')->from('brands')->where('status', 1)->order_by('priority', 'ASC');
$this->data['brands'] = $this->db->get()->result();
//get SEO
$this->db->select('website_name, meta_keywords')->from('configuration')->where('id_configuration', 1);
$website_name = $this->db->get()->row();
$this->data_header['browser_title'] = ucwords($website_name->website_name) . ' - All Brands';
$this->data_header['meta_description'] = ucwords($website_name->website_name) . ' - All Brands';
$this->data_header['meta_keywords'] = $website_name->meta_keywords;
$this->load->view('template/header', $this->data_header);
$this->load->view('all-brands', $this->data);
$this->load->view('template/footer', $this->data_footer);
} else {
//check if brand exist
$this->db->select('*')->from('brands')->where('alias', $alias)->where('status', 1);
$count = $this->db->get()->num_rows();
if ($count == 0) { show_404(); }
//set current brand to session, so it can be track to product page
$this->session->set_userdata('current_viewed_brand', $alias);
//get brand parameters
$this->db->select('*')->from('brands')->where('alias', $alias);
$this->data['brand'] = $this->db->get()->row();
//check if post sort product is exist
if ($this->input->post('sort_product')) {
$this->sort_product_by = $this->input->post('sort_product');
}
//PRODUCTS
//pagination in action.
//get no. of products per page (pagination) from configuration table
$this->db->select('products_displayed')->from('configuration')->where('id_configuration', 1);
$per_page = $this->db->get()->row();
$this->load->library('pagination');
$config = array();
$this->load->helper('pagination_helper');
$config = pagination_format();
$config['base_url'] = base_url() . 'brand/' . $alias;
$this->load->model('product_m');
$config['total_rows'] = $this->product_m->count_products_by_brand($this->data['brand']->id_brands);
$config['per_page'] = $per_page->products_displayed;
$config["uri_segment"] = 3;
$this->pagination->initialize($config);
$this->data['sort_product_by'] = $this->sort_product_by;
$this->data['total_products'] = $config['total_rows'];
$this->data['products'] = $this->product_m->get_products_by_brand($this->data['brand']->id_brands, $config['per_page'], $this->uri->segment(3), $this->sort_product_by);
//get SEO
$this->data_header['browser_title'] = 'Brand - ' . ucwords($this->data['brand']->brand);
$this->data_header['meta_description'] = $this->data['brand']->meta_description;
$this->data_header['meta_keywords'] = $this->data['brand']->meta_keywords;
$this->load->view('template/header', $this->data_header);
$this->load->view('brand', $this->data);
$this->load->view('template/footer', $this->data_footer);
}
}
}