shop.balmet.com

Unnamed repository; edit this file 'description' to name the repository.
Log | Files | Refs | README

tax_rate.php (4146B)


      1 <?php
      2 class ModelLocalisationTaxRate extends Model {
      3 	public function addTaxRate($data) {
      4 		$this->db->query("INSERT INTO " . DB_PREFIX . "tax_rate SET name = '" . $this->db->escape($data['name']) . "', rate = '" . (float)$data['rate'] . "', `type` = '" . $this->db->escape($data['type']) . "', geo_zone_id = '" . (int)$data['geo_zone_id'] . "', date_added = NOW(), date_modified = NOW()");
      5 
      6 		$tax_rate_id = $this->db->getLastId();
      7 
      8 		if (isset($data['tax_rate_customer_group'])) {
      9 			foreach ($data['tax_rate_customer_group'] as $customer_group_id) {
     10 				$this->db->query("INSERT INTO " . DB_PREFIX . "tax_rate_to_customer_group SET tax_rate_id = '" . (int)$tax_rate_id . "', customer_group_id = '" . (int)$customer_group_id . "'");
     11 			}
     12 		}
     13 		
     14 		return $tax_rate_id;
     15 	}
     16 
     17 	public function editTaxRate($tax_rate_id, $data) {
     18 		$this->db->query("UPDATE " . DB_PREFIX . "tax_rate SET name = '" . $this->db->escape($data['name']) . "', rate = '" . (float)$data['rate'] . "', `type` = '" . $this->db->escape($data['type']) . "', geo_zone_id = '" . (int)$data['geo_zone_id'] . "', date_modified = NOW() WHERE tax_rate_id = '" . (int)$tax_rate_id . "'");
     19 
     20 		$this->db->query("DELETE FROM " . DB_PREFIX . "tax_rate_to_customer_group WHERE tax_rate_id = '" . (int)$tax_rate_id . "'");
     21 
     22 		if (isset($data['tax_rate_customer_group'])) {
     23 			foreach ($data['tax_rate_customer_group'] as $customer_group_id) {
     24 				$this->db->query("INSERT INTO " . DB_PREFIX . "tax_rate_to_customer_group SET tax_rate_id = '" . (int)$tax_rate_id . "', customer_group_id = '" . (int)$customer_group_id . "'");
     25 			}
     26 		}
     27 	}
     28 
     29 	public function deleteTaxRate($tax_rate_id) {
     30 		$this->db->query("DELETE FROM " . DB_PREFIX . "tax_rate WHERE tax_rate_id = '" . (int)$tax_rate_id . "'");
     31 		$this->db->query("DELETE FROM " . DB_PREFIX . "tax_rate_to_customer_group WHERE tax_rate_id = '" . (int)$tax_rate_id . "'");
     32 	}
     33 
     34 	public function getTaxRate($tax_rate_id) {
     35 		$query = $this->db->query("SELECT tr.tax_rate_id, tr.name AS name, tr.rate, tr.type, tr.geo_zone_id, gz.name AS geo_zone, tr.date_added, tr.date_modified FROM " . DB_PREFIX . "tax_rate tr LEFT JOIN " . DB_PREFIX . "geo_zone gz ON (tr.geo_zone_id = gz.geo_zone_id) WHERE tr.tax_rate_id = '" . (int)$tax_rate_id . "'");
     36 
     37 		return $query->row;
     38 	}
     39 
     40 	public function getTaxRates($data = array()) {
     41 		$sql = "SELECT tr.tax_rate_id, tr.name AS name, tr.rate, tr.type, gz.name AS geo_zone, tr.date_added, tr.date_modified FROM " . DB_PREFIX . "tax_rate tr LEFT JOIN " . DB_PREFIX . "geo_zone gz ON (tr.geo_zone_id = gz.geo_zone_id)";
     42 
     43 		$sort_data = array(
     44 			'tr.name',
     45 			'tr.rate',
     46 			'tr.type',
     47 			'gz.name',
     48 			'tr.date_added',
     49 			'tr.date_modified'
     50 		);
     51 
     52 		if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
     53 			$sql .= " ORDER BY " . $data['sort'];
     54 		} else {
     55 			$sql .= " ORDER BY tr.name";
     56 		}
     57 
     58 		if (isset($data['order']) && ($data['order'] == 'DESC')) {
     59 			$sql .= " DESC";
     60 		} else {
     61 			$sql .= " ASC";
     62 		}
     63 
     64 		if (isset($data['start']) || isset($data['limit'])) {
     65 			if ($data['start'] < 0) {
     66 				$data['start'] = 0;
     67 			}
     68 
     69 			if ($data['limit'] < 1) {
     70 				$data['limit'] = 20;
     71 			}
     72 
     73 			$sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
     74 		}
     75 
     76 		$query = $this->db->query($sql);
     77 
     78 		return $query->rows;
     79 	}
     80 
     81 	public function getTaxRateCustomerGroups($tax_rate_id) {
     82 		$tax_customer_group_data = array();
     83 
     84 		$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "tax_rate_to_customer_group WHERE tax_rate_id = '" . (int)$tax_rate_id . "'");
     85 
     86 		foreach ($query->rows as $result) {
     87 			$tax_customer_group_data[] = $result['customer_group_id'];
     88 		}
     89 
     90 		return $tax_customer_group_data;
     91 	}
     92 
     93 	public function getTotalTaxRates() {
     94 		$query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "tax_rate");
     95 
     96 		return $query->row['total'];
     97 	}
     98 
     99 	public function getTotalTaxRatesByGeoZoneId($geo_zone_id) {
    100 		$query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "tax_rate WHERE geo_zone_id = '" . (int)$geo_zone_id . "'");
    101 
    102 		return $query->row['total'];
    103 	}
    104 }