/catalog/controller/product/special.php
https://github.com/smadi/arabian-land · PHP · 297 lines · 237 code · 60 blank · 0 comment · 32 complexity · dd8a20c3cc1232d8a34a99a6d403c56f MD5 · raw file
- <?php
- class ControllerProductSpecial extends Controller {
- public function index() {
- $this->language->load('product/special');
-
- $this->load->model('catalog/product');
-
- $this->load->model('tool/image');
-
- if (isset($this->request->get['sort'])) {
- $sort = $this->request->get['sort'];
- } else {
- $sort = 'p.sort_order';
- }
- if (isset($this->request->get['order'])) {
- $order = $this->request->get['order'];
- } else {
- $order = 'ASC';
- }
-
- if (isset($this->request->get['page'])) {
- $page = $this->request->get['page'];
- } else {
- $page = 1;
- }
-
- if (isset($this->request->get['limit'])) {
- $limit = $this->request->get['limit'];
- } else {
- $limit = $this->config->get('config_catalog_limit');
- }
-
- $this->document->setTitle($this->language->get('heading_title'));
- $this->data['breadcrumbs'] = array();
- $this->data['breadcrumbs'][] = array(
- 'text' => $this->language->get('text_home'),
- 'href' => $this->url->link('common/home'),
- 'separator' => false
- );
- $url = '';
-
- if (isset($this->request->get['sort'])) {
- $url .= '&sort=' . $this->request->get['sort'];
- }
- if (isset($this->request->get['order'])) {
- $url .= '&order=' . $this->request->get['order'];
- }
-
- if (isset($this->request->get['page'])) {
- $url .= '&page=' . $this->request->get['page'];
- }
-
- if (isset($this->request->get['limit'])) {
- $url .= '&limit=' . $this->request->get['limit'];
- }
-
- $this->data['breadcrumbs'][] = array(
- 'text' => $this->language->get('heading_title'),
- 'href' => $this->url->link('product/special', $url),
- 'separator' => $this->language->get('text_separator')
- );
-
- $this->data['heading_title'] = $this->language->get('heading_title');
-
- $this->data['text_empty'] = $this->language->get('text_empty');
- $this->data['text_quantity'] = $this->language->get('text_quantity');
- $this->data['text_manufacturer'] = $this->language->get('text_manufacturer');
- $this->data['text_model'] = $this->language->get('text_model');
- $this->data['text_price'] = $this->language->get('text_price');
- $this->data['text_tax'] = $this->language->get('text_tax');
- $this->data['text_points'] = $this->language->get('text_points');
- $this->data['text_compare'] = sprintf($this->language->get('text_compare'), (isset($this->session->data['compare']) ? count($this->session->data['compare']) : 0));
- $this->data['text_display'] = $this->language->get('text_display');
- $this->data['text_list'] = $this->language->get('text_list');
- $this->data['text_grid'] = $this->language->get('text_grid');
- $this->data['text_sort'] = $this->language->get('text_sort');
- $this->data['text_limit'] = $this->language->get('text_limit');
- $this->data['button_cart'] = $this->language->get('button_cart');
- $this->data['button_wishlist'] = $this->language->get('button_wishlist');
- $this->data['button_compare'] = $this->language->get('button_compare');
-
- $this->data['compare'] = $this->url->link('product/compare');
-
- $this->data['products'] = array();
- $data = array(
- 'sort' => $sort,
- 'order' => $order,
- 'start' => ($page - 1) * $limit,
- 'limit' => $limit
- );
-
- $product_total = $this->model_catalog_product->getTotalProductSpecials($data);
-
- $results = $this->model_catalog_product->getProductSpecials($data);
-
- foreach ($results as $result) {
- if ($result['image']) {
- $image = $this->model_tool_image->resize($result['image'], $this->config->get('config_image_product_width'), $this->config->get('config_image_product_height'));
- } else {
- $image = false;
- }
-
- if (($this->config->get('config_customer_price') && $this->customer->isLogged()) || !$this->config->get('config_customer_price')) {
- $price = $this->currency->format($this->tax->calculate($result['price'], $result['tax_class_id'], $this->config->get('config_tax')));
- } else {
- $price = false;
- }
-
- if ((float)$result['special']) {
- $special = $this->currency->format($this->tax->calculate($result['special'], $result['tax_class_id'], $this->config->get('config_tax')));
- } else {
- $special = false;
- }
-
- if ($this->config->get('config_tax')) {
- $tax = $this->currency->format((float)$result['special'] ? $result['special'] : $result['price']);
- } else {
- $tax = false;
- }
-
- if ($this->config->get('config_review_status')) {
- $rating = (int)$result['rating'];
- } else {
- $rating = false;
- }
-
- $this->data['products'][] = array(
- 'product_id' => $result['product_id'],
- 'thumb' => $image,
- 'name' => $result['name'],
- 'description' => substr(strip_tags(html_entity_decode($result['description'], ENT_QUOTES, 'UTF-8')), 0, 100) . '..',
- 'price' => $price,
- 'special' => $special,
- 'tax' => $tax,
- 'rating' => $result['rating'],
- 'reviews' => sprintf($this->language->get('text_reviews'), (int)$result['reviews']),
- 'href' => $this->url->link('product/product', $url . '&product_id=' . $result['product_id'])
- );
- }
- $url = '';
- if (isset($this->request->get['limit'])) {
- $url .= '&limit=' . $this->request->get['limit'];
- }
-
- $this->data['sorts'] = array();
-
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_default'),
- 'value' => 'p.sort_order-ASC',
- 'href' => $this->url->link('product/special', 'sort=p.sort_order&order=ASC' . $url)
- );
-
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_name_asc'),
- 'value' => 'pd.name-ASC',
- 'href' => $this->url->link('product/special', 'sort=pd.name&order=ASC' . $url)
- );
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_name_desc'),
- 'value' => 'pd.name-DESC',
- 'href' => $this->url->link('product/special', 'sort=pd.name&order=DESC' . $url)
- );
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_price_asc'),
- 'value' => 'ps.price-ASC',
- 'href' => $this->url->link('product/special', 'sort=ps.price&order=ASC' . $url)
- );
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_price_desc'),
- 'value' => 'special-DESC',
- 'href' => $this->url->link('product/special', 'sort=special&order=DESC' . $url)
- );
-
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_rating_desc'),
- 'value' => 'rating-DESC',
- 'href' => $this->url->link('product/special', 'sort=rating&order=DESC' . $url)
- );
-
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_rating_asc'),
- 'value' => 'rating-ASC',
- 'href' => $this->url->link('product/special', 'sort=rating&order=ASC' . $url)
- );
-
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_model_asc'),
- 'value' => 'p.model-ASC',
- 'href' => $this->url->link('product/special', 'sort=p.model&order=ASC' . $url)
- );
- $this->data['sorts'][] = array(
- 'text' => $this->language->get('text_model_desc'),
- 'value' => 'p.model-DESC',
- 'href' => $this->url->link('product/special', 'sort=p.model&order=DESC' . $url)
- );
-
- $url = '';
- if (isset($this->request->get['sort'])) {
- $url .= '&sort=' . $this->request->get['sort'];
- }
- if (isset($this->request->get['order'])) {
- $url .= '&order=' . $this->request->get['order'];
- }
-
- $this->data['limits'] = array();
-
- $this->data['limits'][] = array(
- 'text' => $this->config->get('config_catalog_limit'),
- 'value' => $this->config->get('config_catalog_limit'),
- 'href' => $this->url->link('product/special', $url . '&limit=' . $this->config->get('config_catalog_limit'))
- );
-
- $this->data['limits'][] = array(
- 'text' => 25,
- 'value' => 25,
- 'href' => $this->url->link('product/special', $url . '&limit=25')
- );
-
- $this->data['limits'][] = array(
- 'text' => 50,
- 'value' => 50,
- 'href' => $this->url->link('product/special', $url . '&limit=50')
- );
- $this->data['limits'][] = array(
- 'text' => 75,
- 'value' => 75,
- 'href' => $this->url->link('product/special', $url . '&limit=75')
- );
-
- $this->data['limits'][] = array(
- 'text' => 100,
- 'value' => 100,
- 'href' => $this->url->link('product/special', $url . '&limit=100')
- );
- $url = '';
- if (isset($this->request->get['sort'])) {
- $url .= '&sort=' . $this->request->get['sort'];
- }
- if (isset($this->request->get['order'])) {
- $url .= '&order=' . $this->request->get['order'];
- }
-
- if (isset($this->request->get['limit'])) {
- $url .= '&limit=' . $this->request->get['limit'];
- }
-
- $pagination = new Pagination();
- $pagination->total = $product_total;
- $pagination->page = $page;
- $pagination->limit = $limit;
- $pagination->text = $this->language->get('text_pagination');
- $pagination->url = $this->url->link('product/special', $url . '&page={page}');
-
- $this->data['pagination'] = $pagination->render();
-
- $this->data['sort'] = $sort;
- $this->data['order'] = $order;
- $this->data['limit'] = $limit;
- if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/product/special.tpl')) {
- $this->template = $this->config->get('config_template') . '/template/product/special.tpl';
- } else {
- $this->template = 'default/template/product/special.tpl';
- }
-
- $this->children = array(
- 'common/column_left',
- 'common/column_right',
- 'common/content_top',
- 'common/content_bottom',
- 'common/footer',
- 'common/header'
- );
-
- $this->response->setOutput($this->render());
- }
- }
- ?>