PageRenderTime 77ms CodeModel.GetById 24ms RepoModel.GetById 0ms app.codeStats 0ms

/catalog/model/catalog/orig_product.php

https://bitbucket.org/monobasic/shop.volero.ch
PHP | 501 lines | 377 code | 124 blank | 0 comment | 92 complexity | 2f6b5c3b609a69a675f71b34af0da1ec MD5 | raw file
  1. <?php
  2. class ModelCatalogProduct extends Model {
  3. public function updateViewed($product_id) {
  4. $this->db->query("UPDATE " . DB_PREFIX . "product SET viewed = (viewed + 1) WHERE product_id = '" . (int)$product_id . "'");
  5. }
  6. public function getProduct($product_id) {
  7. if ($this->customer->isLogged()) {
  8. $customer_group_id = $this->customer->getCustomerGroupId();
  9. } else {
  10. $customer_group_id = $this->config->get('config_customer_group_id');
  11. }
  12. $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$customer_group_id . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$customer_group_id . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND customer_group_id = '" . (int)$customer_group_id . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");
  13. if ($query->num_rows) {
  14. $query->row['price'] = ($query->row['discount'] ? $query->row['discount'] : $query->row['price']);
  15. $query->row['rating'] = (int)$query->row['rating'];
  16. return $query->row;
  17. } else {
  18. return false;
  19. }
  20. }
  21. public function getProducts($data = array()) {
  22. if ($this->customer->isLogged()) {
  23. $customer_group_id = $this->customer->getCustomerGroupId();
  24. } else {
  25. $customer_group_id = $this->config->get('config_customer_group_id');
  26. }
  27. $cache = md5(http_build_query($data));
  28. $product_data = $this->cache->get('product.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$customer_group_id . '.' . $cache);
  29. if (!$product_data) {
  30. $sql = "SELECT p.product_id, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id)";
  31. if (!empty($data['filter_tag'])) {
  32. $sql .= " LEFT JOIN " . DB_PREFIX . "product_tag pt ON (p.product_id = pt.product_id)";
  33. }
  34. if (!empty($data['filter_category_id'])) {
  35. $sql .= " LEFT JOIN " . DB_PREFIX . "product_to_category p2c ON (p.product_id = p2c.product_id)";
  36. }
  37. $sql .= " WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'";
  38. if (!empty($data['filter_name']) || !empty($data['filter_tag'])) {
  39. $sql .= " AND (";
  40. if (!empty($data['filter_name'])) {
  41. $implode = array();
  42. $words = explode(' ', $data['filter_name']);
  43. foreach ($words as $word) {
  44. if (!empty($data['filter_description'])) {
  45. $implode[] = "LCASE(pd.name) LIKE '%" . $this->db->escape(utf8_strtolower($word)) . "%' OR LCASE(pd.description) LIKE '%" . $this->db->escape(utf8_strtolower($word)) . "%'";
  46. } else {
  47. $implode[] = "LCASE(pd.name) LIKE '%" . $this->db->escape(utf8_strtolower($word)) . "%'";
  48. }
  49. }
  50. if ($implode) {
  51. $sql .= " " . implode(" OR ", $implode) . "";
  52. }
  53. }
  54. if (!empty($data['filter_name']) && !empty($data['filter_tag'])) {
  55. $sql .= " OR ";
  56. }
  57. if (!empty($data['filter_tag'])) {
  58. $implode = array();
  59. $words = explode(' ', $data['filter_tag']);
  60. foreach ($words as $word) {
  61. $implode[] = "LCASE(pt.tag) LIKE '%" . $this->db->escape(utf8_strtolower($data['filter_tag'])) . "%' AND pt.language_id = '" . (int)$this->config->get('config_language_id') . "'";
  62. }
  63. if ($implode) {
  64. $sql .= " " . implode(" OR ", $implode) . "";
  65. }
  66. }
  67. $sql .= ")";
  68. }
  69. if (!empty($data['filter_category_id'])) {
  70. if (!empty($data['filter_sub_category'])) {
  71. $implode_data = array();
  72. $implode_data[] = "p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
  73. $this->load->model('catalog/category');
  74. $categories = $this->model_catalog_category->getCategoriesByParentId($data['filter_category_id']);
  75. foreach ($categories as $category_id) {
  76. $implode_data[] = "p2c.category_id = '" . (int)$category_id . "'";
  77. }
  78. $sql .= " AND (" . implode(' OR ', $implode_data) . ")";
  79. } else {
  80. $sql .= " AND p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
  81. }
  82. }
  83. if (!empty($data['filter_manufacturer_id'])) {
  84. $sql .= " AND p.manufacturer_id = '" . (int)$data['filter_manufacturer_id'] . "'";
  85. }
  86. $sql .= " GROUP BY p.product_id";
  87. $sort_data = array(
  88. 'pd.name',
  89. 'p.model',
  90. 'p.quantity',
  91. 'p.price',
  92. 'rating',
  93. 'p.sort_order',
  94. 'p.date_added'
  95. );
  96. if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
  97. if ($data['sort'] == 'pd.name' || $data['sort'] == 'p.model') {
  98. $sql .= " ORDER BY LCASE(" . $data['sort'] . ")";
  99. } else {
  100. $sql .= " ORDER BY " . $data['sort'];
  101. }
  102. } else {
  103. $sql .= " ORDER BY p.sort_order";
  104. }
  105. if (isset($data['order']) && ($data['order'] == 'DESC')) {
  106. $sql .= " DESC";
  107. } else {
  108. $sql .= " ASC";
  109. }
  110. if (isset($data['start']) || isset($data['limit'])) {
  111. if ($data['start'] < 0) {
  112. $data['start'] = 0;
  113. }
  114. if ($data['limit'] < 1) {
  115. $data['limit'] = 20;
  116. }
  117. $sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
  118. }
  119. $product_data = array();
  120. $query = $this->db->query($sql);
  121. foreach ($query->rows as $result) {
  122. $product_data[$result['product_id']] = $this->getProduct($result['product_id']);
  123. }
  124. $this->cache->set('product.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$customer_group_id . '.' . $cache, $product_data);
  125. }
  126. return $product_data;
  127. }
  128. public function getProductSpecials($data = array()) {
  129. if ($this->customer->isLogged()) {
  130. $customer_group_id = $this->customer->getCustomerGroupId();
  131. } else {
  132. $customer_group_id = $this->config->get('config_customer_group_id');
  133. }
  134. $sql = "SELECT DISTINCT ps.product_id, (SELECT AVG(rating) FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = ps.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating FROM " . DB_PREFIX . "product_special ps LEFT JOIN " . DB_PREFIX . "product p ON (ps.product_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' AND ps.customer_group_id = '" . (int)$customer_group_id . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) GROUP BY ps.product_id";
  135. $sort_data = array(
  136. 'pd.name',
  137. 'p.model',
  138. 'ps.price',
  139. 'rating',
  140. 'p.sort_order'
  141. );
  142. if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
  143. if ($data['sort'] == 'pd.name' || $data['sort'] == 'p.model') {
  144. $sql .= " ORDER BY LCASE(" . $data['sort'] . ")";
  145. } else {
  146. $sql .= " ORDER BY " . $data['sort'];
  147. }
  148. } else {
  149. $sql .= " ORDER BY p.sort_order";
  150. }
  151. if (isset($data['order']) && ($data['order'] == 'DESC')) {
  152. $sql .= " DESC";
  153. } else {
  154. $sql .= " ASC";
  155. }
  156. if (isset($data['start']) || isset($data['limit'])) {
  157. if ($data['start'] < 0) {
  158. $data['start'] = 0;
  159. }
  160. if ($data['limit'] < 1) {
  161. $data['limit'] = 20;
  162. }
  163. $sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
  164. }
  165. $product_data = array();
  166. $query = $this->db->query($sql);
  167. foreach ($query->rows as $result) {
  168. $product_data[$result['product_id']] = $this->getProduct($result['product_id']);
  169. }
  170. return $product_data;
  171. }
  172. public function getLatestProducts($limit) {
  173. $product_data = $this->cache->get('product.latest.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$limit);
  174. if (!$product_data) {
  175. $query = $this->db->query("SELECT p.product_id FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' ORDER BY p.date_added DESC LIMIT " . (int)$limit);
  176. foreach ($query->rows as $result) {
  177. $product_data[$result['product_id']] = $this->getProduct($result['product_id']);
  178. }
  179. $this->cache->set('product.latest.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$limit, $product_data);
  180. }
  181. return $product_data;
  182. }
  183. public function getPopularProducts($limit) {
  184. $product_data = array();
  185. $query = $this->db->query("SELECT p.product_id FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' ORDER BY p.viewed, p.date_added DESC LIMIT " . (int)$limit);
  186. foreach ($query->rows as $result) {
  187. $product_data[$result['product_id']] = $this->getProduct($result['product_id']);
  188. }
  189. return $product_data;
  190. }
  191. public function getBestSellerProducts($limit) {
  192. $product_data = $this->cache->get('product.bestseller.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$limit);
  193. if (!$product_data) {
  194. $product_data = array();
  195. $query = $this->db->query("SELECT op.product_id, COUNT(*) AS total FROM " . DB_PREFIX . "order_product op LEFT JOIN `" . DB_PREFIX . "order` o ON (op.order_id = o.order_id) LEFT JOIN `" . DB_PREFIX . "product` p ON (op.product_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE o.order_status_id > '0' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' GROUP BY op.product_id ORDER BY total DESC LIMIT " . (int)$limit);
  196. foreach ($query->rows as $result) {
  197. $product_data[$result['product_id']] = $this->getProduct($result['product_id']);
  198. }
  199. $this->cache->set('product.bestseller.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$limit, $product_data);
  200. }
  201. return $product_data;
  202. }
  203. public function getProductAttributes($product_id) {
  204. $product_attribute_group_data = array();
  205. $product_attribute_group_query = $this->db->query("SELECT ag.attribute_group_id, agd.name FROM " . DB_PREFIX . "product_attribute pa LEFT JOIN " . DB_PREFIX . "attribute a ON (pa.attribute_id = a.attribute_id) LEFT JOIN " . DB_PREFIX . "attribute_group ag ON (a.attribute_group_id = ag.attribute_group_id) LEFT JOIN " . DB_PREFIX . "attribute_group_description agd ON (ag.attribute_group_id = agd.attribute_group_id) WHERE pa.product_id = '" . (int)$product_id . "' AND agd.language_id = '" . (int)$this->config->get('config_language_id') . "' GROUP BY ag.attribute_group_id ORDER BY ag.sort_order, agd.name");
  206. foreach ($product_attribute_group_query->rows as $product_attribute_group) {
  207. $product_attribute_data = array();
  208. $product_attribute_query = $this->db->query("SELECT a.attribute_id, ad.name, pa.text FROM " . DB_PREFIX . "product_attribute pa LEFT JOIN " . DB_PREFIX . "attribute a ON (pa.attribute_id = a.attribute_id) LEFT JOIN " . DB_PREFIX . "attribute_description ad ON (a.attribute_id = ad.attribute_id) WHERE pa.product_id = '" . (int)$product_id . "' AND a.attribute_group_id = '" . (int)$product_attribute_group['attribute_group_id'] . "' AND ad.language_id = '" . (int)$this->config->get('config_language_id') . "' AND pa.language_id = '" . (int)$this->config->get('config_language_id') . "' ORDER BY a.sort_order, ad.name");
  209. foreach ($product_attribute_query->rows as $product_attribute) {
  210. $product_attribute_data[] = array(
  211. 'attribute_id' => $product_attribute['attribute_id'],
  212. 'name' => $product_attribute['name'],
  213. 'text' => $product_attribute['text']
  214. );
  215. }
  216. $product_attribute_group_data[] = array(
  217. 'attribute_group_id' => $product_attribute_group['attribute_group_id'],
  218. 'name' => $product_attribute_group['name'],
  219. 'attribute' => $product_attribute_data
  220. );
  221. }
  222. return $product_attribute_group_data;
  223. }
  224. public function getProductOptions($product_id) {
  225. $product_option_data = array();
  226. $product_option_query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_option po LEFT JOIN `" . DB_PREFIX . "option` o ON (po.option_id = o.option_id) LEFT JOIN " . DB_PREFIX . "option_description od ON (o.option_id = od.option_id) WHERE po.product_id = '" . (int)$product_id . "' AND od.language_id = '" . (int)$this->config->get('config_language_id') . "' ORDER BY o.sort_order");
  227. foreach ($product_option_query->rows as $product_option) {
  228. if ($product_option['type'] == 'select' || $product_option['type'] == 'radio' || $product_option['type'] == 'checkbox' || $product_option['type'] == 'image') {
  229. $product_option_value_data = array();
  230. $product_option_value_query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_option_value pov LEFT JOIN " . DB_PREFIX . "option_value ov ON (pov.option_value_id = ov.option_value_id) LEFT JOIN " . DB_PREFIX . "option_value_description ovd ON (ov.option_value_id = ovd.option_value_id) WHERE pov.product_id = '" . (int)$product_id . "' AND pov.product_option_id = '" . (int)$product_option['product_option_id'] . "' AND ovd.language_id = '" . (int)$this->config->get('config_language_id') . "' ORDER BY ov.sort_order");
  231. foreach ($product_option_value_query->rows as $product_option_value) {
  232. $product_option_value_data[] = array(
  233. 'product_option_value_id' => $product_option_value['product_option_value_id'],
  234. 'option_value_id' => $product_option_value['option_value_id'],
  235. 'name' => $product_option_value['name'],
  236. 'image' => $product_option_value['image'],
  237. 'quantity' => $product_option_value['quantity'],
  238. 'subtract' => $product_option_value['subtract'],
  239. 'price' => $product_option_value['price'],
  240. 'price_prefix' => $product_option_value['price_prefix'],
  241. 'weight' => $product_option_value['weight'],
  242. 'weight_prefix' => $product_option_value['weight_prefix']
  243. );
  244. }
  245. $product_option_data[] = array(
  246. 'product_option_id' => $product_option['product_option_id'],
  247. 'option_id' => $product_option['option_id'],
  248. 'name' => $product_option['name'],
  249. 'type' => $product_option['type'],
  250. 'option_value' => $product_option_value_data,
  251. 'required' => $product_option['required']
  252. );
  253. } else {
  254. $product_option_data[] = array(
  255. 'product_option_id' => $product_option['product_option_id'],
  256. 'option_id' => $product_option['option_id'],
  257. 'name' => $product_option['name'],
  258. 'type' => $product_option['type'],
  259. 'option_value' => $product_option['option_value'],
  260. 'required' => $product_option['required']
  261. );
  262. }
  263. }
  264. return $product_option_data;
  265. }
  266. public function getProductDiscounts($product_id) {
  267. if ($this->customer->isLogged()) {
  268. $customer_group_id = $this->customer->getCustomerGroupId();
  269. } else {
  270. $customer_group_id = $this->config->get('config_customer_group_id');
  271. }
  272. $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_discount WHERE product_id = '" . (int)$product_id . "' AND customer_group_id = '" . (int)$customer_group_id . "' AND quantity > 1 AND ((date_start = '0000-00-00' OR date_start < NOW()) AND (date_end = '0000-00-00' OR date_end > NOW())) ORDER BY quantity ASC, priority ASC, price ASC");
  273. return $query->rows;
  274. }
  275. public function getProductImages($product_id) {
  276. $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_image WHERE product_id = '" . (int)$product_id . "' ORDER BY sort_order ASC");
  277. return $query->rows;
  278. }
  279. public function getProductRelated($product_id) {
  280. $product_data = array();
  281. $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_related pr LEFT JOIN " . DB_PREFIX . "product p ON (pr.related_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE pr.product_id = '" . (int)$product_id . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");
  282. foreach ($query->rows as $result) {
  283. $product_data[$result['related_id']] = $this->getProduct($result['related_id']);
  284. }
  285. return $product_data;
  286. }
  287. public function getProductTags($product_id) {
  288. $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_tag WHERE product_id = '" . (int)$product_id . "' AND language_id = '" . (int)$this->config->get('config_language_id') . "'");
  289. return $query->rows;
  290. }
  291. public function getProductLayoutId($product_id) {
  292. $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_to_layout WHERE product_id = '" . (int)$product_id . "' AND store_id = '" . (int)$this->config->get('config_store_id') . "'");
  293. if ($query->num_rows) {
  294. return $query->row['layout_id'];
  295. } else {
  296. return $this->config->get('config_layout_product');
  297. }
  298. }
  299. public function getCategories($product_id) {
  300. $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_to_category WHERE product_id = '" . (int)$product_id . "'");
  301. return $query->rows;
  302. }
  303. public function getTotalProducts($data = array()) {
  304. $sql = "SELECT COUNT(DISTINCT p.product_id) AS total FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id)";
  305. if (!empty($data['filter_category_id'])) {
  306. $sql .= " LEFT JOIN " . DB_PREFIX . "product_to_category p2c ON (p.product_id = p2c.product_id)";
  307. }
  308. if (!empty($data['filter_tag'])) {
  309. $sql .= " LEFT JOIN " . DB_PREFIX . "product_tag pt ON (p.product_id = pt.product_id)";
  310. }
  311. $sql .= " WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'";
  312. if (!empty($data['filter_name']) || !empty($data['filter_tag'])) {
  313. $sql .= " AND (";
  314. if (!empty($data['filter_name'])) {
  315. $implode = array();
  316. $words = explode(' ', $data['filter_name']);
  317. foreach ($words as $word) {
  318. if (!empty($data['filter_description'])) {
  319. $implode[] = "LCASE(pd.name) LIKE '%" . $this->db->escape(utf8_strtolower($word)) . "%' OR LCASE(pd.description) LIKE '%" . $this->db->escape(utf8_strtolower($word)) . "%'";
  320. } else {
  321. $implode[] = "LCASE(pd.name) LIKE '%" . $this->db->escape(utf8_strtolower($word)) . "%'";
  322. }
  323. }
  324. if ($implode) {
  325. $sql .= " " . implode(" OR ", $implode) . "";
  326. }
  327. }
  328. if (!empty($data['filter_name']) && !empty($data['filter_tag'])) {
  329. $sql .= " OR ";
  330. }
  331. if (!empty($data['filter_tag'])) {
  332. $implode = array();
  333. $words = explode(' ', $data['filter_tag']);
  334. foreach ($words as $word) {
  335. $implode[] = "LCASE(pt.tag) LIKE '%" . $this->db->escape(utf8_strtolower($data['filter_tag'])) . "%' AND pt.language_id = '" . (int)$this->config->get('config_language_id') . "'";
  336. }
  337. if ($implode) {
  338. $sql .= " " . implode(" OR ", $implode) . "";
  339. }
  340. }
  341. $sql .= ")";
  342. }
  343. if (!empty($data['filter_category_id'])) {
  344. if (!empty($data['filter_sub_category'])) {
  345. $implode_data = array();
  346. $implode_data[] = "p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
  347. $this->load->model('catalog/category');
  348. $categories = $this->model_catalog_category->getCategoriesByParentId($data['filter_category_id']);
  349. foreach ($categories as $category_id) {
  350. $implode_data[] = "p2c.category_id = '" . (int)$category_id . "'";
  351. }
  352. $sql .= " AND (" . implode(' OR ', $implode_data) . ")";
  353. } else {
  354. $sql .= " AND p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
  355. }
  356. }
  357. if (!empty($data['filter_manufacturer_id'])) {
  358. $sql .= " AND p.manufacturer_id = '" . (int)$data['filter_manufacturer_id'] . "'";
  359. }
  360. $query = $this->db->query($sql);
  361. return $query->row['total'];
  362. }
  363. public function getTotalProductSpecials() {
  364. if ($this->customer->isLogged()) {
  365. $customer_group_id = $this->customer->getCustomerGroupId();
  366. } else {
  367. $customer_group_id = $this->config->get('config_customer_group_id');
  368. }
  369. $query = $this->db->query("SELECT COUNT(DISTINCT ps.product_id) AS total FROM " . DB_PREFIX . "product_special ps LEFT JOIN " . DB_PREFIX . "product p ON (ps.product_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' AND ps.customer_group_id = '" . (int)$customer_group_id . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW()))");
  370. if (isset($query->row['total'])) {
  371. return $query->row['total'];
  372. } else {
  373. return 0;
  374. }
  375. }
  376. }
  377. ?>