search.php
4.11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
<?php
// *	@source		See SOURCE.txt for source and other copyright.
// *	@license	GNU General Public License version 3; see LICENSE.txt
class ModelSearchSearch extends Model {
    public function getProducts($data = array()) {
        $sql = "SELECT p.product_id, pd.name, p.model, p.image
                FROM " . DB_PREFIX . "product p
                LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id)
                WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "'
                    AND ( pd.name LIKE '" . $this->db->escape($data['query']) . "%'
                          OR p.model LIKE '" . $this->db->escape($data['query']) . "%'
                          OR p.sku LIKE '" . $this->db->escape($data['query']) . "%'
                        )
                GROUP BY p.product_id
                ORDER BY pd.name ASC
                LIMIT 5";
        $query = $this->db->query($sql);
        return $query->rows;
    }
    public function getCategories($data = array()) {
        $sql = "SELECT cp.category_id AS category_id, GROUP_CONCAT(cdpath.name ORDER BY cp.level SEPARATOR '  >  ') AS name, cmain.image
                FROM " . DB_PREFIX . "category_path cp
                LEFT JOIN " . DB_PREFIX . "category cmain ON (cp.category_id = cmain.category_id)
                LEFT JOIN " . DB_PREFIX . "category cpath ON (cp.path_id = cpath.category_id)
                LEFT JOIN " . DB_PREFIX . "category_description cdmain ON (cp.category_id = cdmain.category_id)
                LEFT JOIN " . DB_PREFIX . "category_description cdpath ON (cp.path_id = cdpath.category_id)
                WHERE cdpath.language_id = '" . (int)$this->config->get('config_language_id') . "'
                    AND cdmain.language_id = '" . (int)$this->config->get('config_language_id') . "'
                    AND cdmain.name LIKE '%" . $this->db->escape($data['query']) . "%'
                GROUP BY cp.category_id
                ORDER BY name ASC
                LIMIT 5";
        $query = $this->db->query($sql);
        return $query->rows;
    }
    public function getManufacturers($data = array()) {
        $sql = "SELECT DISTINCT m.manufacturer_id, m.name, m.image
                FROM " . DB_PREFIX . "manufacturer m
                LEFT JOIN " . DB_PREFIX . "manufacturer_description md ON (m.manufacturer_id = m.manufacturer_id)
                WHERE m.name LIKE '" . $this->db->escape($data['query']) . "%'
                ORDER BY m.name ASC
                LIMIT 5";
        $query = $this->db->query($sql);
        return $query->rows;
    }
    public function getCustomers($data = array()) {
        $sql = "SELECT customer_id, email, CONCAT(c.firstname, ' ', c.lastname) AS name
                FROM " . DB_PREFIX . "customer c
                WHERE c.firstname LIKE '" . $this->db->escape($data['query']) . "%'
                    OR c.email LIKE '" . $this->db->escape($data['query']) . "%'
                    OR c.lastname LIKE '" . $this->db->escape($data['query']) . "%'
                ORDER BY name ASC
                LIMIT 5";
        $query = $this->db->query($sql);
        return $query->rows;
    }
    public function getOrders($data = array()) {
        $sql = "SELECT o.order_id, CONCAT(o.firstname, ' ', o.lastname) AS customer, o.total, o.currency_code, o.currency_value, o.date_added, o.email
                FROM `" . DB_PREFIX . "order` o
                WHERE o.order_status_id > '0'
                AND (o.order_id = '" . (int)$this->db->escape($data['query']) . "'
                     OR o.firstname LIKE '" . $this->db->escape($data['query']) . "%'
                     OR o.email LIKE '" . $this->db->escape($data['query']) . "%'
                     OR o.lastname LIKE '" . $this->db->escape($data['query']) . "%'
                     OR CONCAT(o.invoice_prefix, o.invoice_no) LIKE '" . $this->db->escape($data['query']) . "%')
                ORDER BY o.order_id ASC
                LIMIT 5";
        $query = $this->db->query($sql);
        return $query->rows;
    }
}