OpenCart 🇺🇦

Класс ModelLocalisationZone extends Model { ... }

Тип Возвр. Описание
public mixed addZone ( $data )
Исходный код метода:
$this->db->query("INSERT INTO " . DB_PREFIX . "zone SET status = '" . (int)$data['status'] . "', name = '" . $this->db->escape($data['name']) . "', code = '" . $this->db->escape($data['code']) . "', country_id = '" . (int)$data['country_id'] . "'");

$this->cache->delete('zone');
public mixed editZone ( $zone_id, $data )
Исходный код метода:
$this->db->query("UPDATE " . DB_PREFIX . "zone SET status = '" . (int)$data['status'] . "', name = '" . $this->db->escape($data['name']) . "', code = '" . $this->db->escape($data['code']) . "', country_id = '" . (int)$data['country_id'] . "' WHERE zone_id = '" . (int)$zone_id . "'");

$this->cache->delete('zone');
public mixed deleteZone ( $zone_id )
Исходный код метода:
$this->db->query("DELETE FROM " . DB_PREFIX . "zone WHERE zone_id = '" . (int)$zone_id . "'");

$this->cache->delete('zone');	
public mixed getZone ( $zone_id )
Исходный код метода:
$query = $this->db->query("SELECT DISTINCT * FROM " . DB_PREFIX . "zone WHERE zone_id = '" . (int)$zone_id . "'");

return $query->row;
public mixed getZones ( $data = array() )
Исходный код метода:
$sql = "SELECT *, z.name, c.name AS country FROM " . DB_PREFIX . "zone z LEFT JOIN " . DB_PREFIX . "country c ON (z.country_id = c.country_id)";

$sort_data = array(
	'c.name',
	'z.name',
	'z.code'
);	

if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
	$sql .= " ORDER BY " . $data['sort'];	
} else {
	$sql .= " ORDER BY c.name";	
}

if (isset($data['order']) && ($data['order'] == 'DESC')) {
	$sql .= " DESC";
} else {
	$sql .= " ASC";
}

if (isset($data['start']) || isset($data['limit'])) {
	if ($data['start'] < 0) {
		$data['start'] = 0;
	}		

	if ($data['limit'] < 1) {
		$data['limit'] = 20;
	}	

	$sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
}

$query = $this->db->query($sql);

return $query->rows;
public mixed getZonesByCountryId ( $country_id )
Исходный код метода:
$zone_data = $this->cache->get('zone.' . (int)$country_id);

if (!$zone_data) {
	$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "zone WHERE country_id = '" . (int)$country_id . "' AND status = '1' ORDER BY name");

	$zone_data = $query->rows;

	$this->cache->set('zone.' . (int)$country_id, $zone_data);
}

return $zone_data;
public mixed getTotalZones ( )
Исходный код метода:
$query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "zone");

return $query->row['total'];
public mixed getTotalZonesByCountryId ( $country_id )
Исходный код метода:
$query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "zone WHERE country_id = '" . (int)$country_id . "'");

return $query->row['total'];

Связанные классы:

Название класса Роль
class Cache { ... } Компонент Cache используется в данном классе
class DB { ... } Компонент Db используется в данном классе

Комментарии