OpenCart 🇺🇦

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

Тип Возвр. Описание
public int addAddress ( array $data )
Исходный код метода:
$this->db->query("INSERT INTO " . DB_PREFIX . "address SET customer_id = '" . (int)$this->customer->getId() . "', firstname = '" . $this->db->escape($data['firstname']) . "', lastname = '" . $this->db->escape($data['lastname']) . "', company = '" . $this->db->escape($data['company']) . "', company_id = '" . $this->db->escape(isset($data['company_id']) ? $data['company_id'] : '') . "', tax_id = '" . $this->db->escape(isset($data['tax_id']) ? $data['tax_id'] : '') . "', address_1 = '" . $this->db->escape($data['address_1']) . "', address_2 = '" . $this->db->escape($data['address_2']) . "', postcode = '" . $this->db->escape($data['postcode']) . "', city = '" . $this->db->escape($data['city']) . "', zone_id = '" . (int)$data['zone_id'] . "', country_id = '" . (int)$data['country_id'] . "'");

$address_id = $this->db->getLastId();

if (!empty($data['default'])) {
	$this->db->query("UPDATE " . DB_PREFIX . "customer SET address_id = '" . (int)$address_id . "' WHERE customer_id = '" . (int)$this->customer->getId() . "'");
}

return $address_id;
public mixed editAddress ( $address_id, $data )
Исходный код метода:
$this->db->query("UPDATE " . DB_PREFIX . "address SET firstname = '" . $this->db->escape($data['firstname']) . "', lastname = '" . $this->db->escape($data['lastname']) . "', company = '" . $this->db->escape($data['company']) . "', company_id = '" . $this->db->escape(isset($data['company_id']) ? $data['company_id'] : '') . "', tax_id = '" . $this->db->escape(isset($data['tax_id']) ? $data['tax_id'] : '') . "', address_1 = '" . $this->db->escape($data['address_1']) . "', address_2 = '" . $this->db->escape($data['address_2']) . "', postcode = '" . $this->db->escape($data['postcode']) . "', city = '" . $this->db->escape($data['city']) . "', zone_id = '" . (int)$data['zone_id'] . "', country_id = '" . (int)$data['country_id'] . "' WHERE address_id  = '" . (int)$address_id . "' AND customer_id = '" . (int)$this->customer->getId() . "'");

if (!empty($data['default'])) {
	$this->db->query("UPDATE " . DB_PREFIX . "customer SET address_id = '" . (int)$address_id . "' WHERE customer_id = '" . (int)$this->customer->getId() . "'");
}
public void deleteAddress ( int $address_id )
Исходный код метода:
$this->db->query("DELETE FROM " . DB_PREFIX . "address WHERE address_id = '" . (int)$address_id . "' AND customer_id = '" . (int)$this->customer->getId() . "'");
public mixed getAddress ( $address_id )
Исходный код метода:
$address_query = $this->db->query("SELECT DISTINCT * FROM " . DB_PREFIX . "address WHERE address_id = '" . (int)$address_id . "' AND customer_id = '" . (int)$this->customer->getId() . "'");

if ($address_query->num_rows) {
	$country_query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "country` WHERE country_id = '" . (int)$address_query->row['country_id'] . "'");
	
	if ($country_query->num_rows) {
		$country = $country_query->row['name'];
		$iso_code_2 = $country_query->row['iso_code_2'];
		$iso_code_3 = $country_query->row['iso_code_3'];
		$address_format = $country_query->row['address_format'];
	} else {
		$country = '';
		$iso_code_2 = '';
		$iso_code_3 = '';	
		$address_format = '';
	}
	
	$zone_query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "zone` WHERE zone_id = '" . (int)$address_query->row['zone_id'] . "'");
	
	if ($zone_query->num_rows) {
		$zone = $zone_query->row['name'];
		$zone_code = $zone_query->row['code'];
	} else {
		$zone = '';
		$zone_code = '';
	}		
	
	$address_data = array(
		'firstname'      => $address_query->row['firstname'],
		'lastname'       => $address_query->row['lastname'],
		'company'        => $address_query->row['company'],
		'company_id'     => $address_query->row['company_id'],
		'tax_id'         => $address_query->row['tax_id'],
		'address_1'      => $address_query->row['address_1'],
		'address_2'      => $address_query->row['address_2'],
		'postcode'       => $address_query->row['postcode'],
		'city'           => $address_query->row['city'],
		'zone_id'        => $address_query->row['zone_id'],
		'zone'           => $zone,
		'zone_code'      => $zone_code,
		'country_id'     => $address_query->row['country_id'],
		'country'        => $country,	
		'iso_code_2'     => $iso_code_2,
		'iso_code_3'     => $iso_code_3,
		'address_format' => $address_format
	);
	
	return $address_data;
} else {
	return false;	
}
public mixed getAddresses ( )
Исходный код метода:
$address_data = array();

$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "address WHERE customer_id = '" . (int)$this->customer->getId() . "'");

foreach ($query->rows as $result) {
	$country_query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "country` WHERE country_id = '" . (int)$result['country_id'] . "'");
	
	if ($country_query->num_rows) {
		$country = $country_query->row['name'];
		$iso_code_2 = $country_query->row['iso_code_2'];
		$iso_code_3 = $country_query->row['iso_code_3'];
		$address_format = $country_query->row['address_format'];
	} else {
		$country = '';
		$iso_code_2 = '';
		$iso_code_3 = '';	
		$address_format = '';
	}
	
	$zone_query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "zone` WHERE zone_id = '" . (int)$result['zone_id'] . "'");
	
	if ($zone_query->num_rows) {
		$zone = $zone_query->row['name'];
		$zone_code = $zone_query->row['code'];
	} else {
		$zone = '';
		$zone_code = '';
	}		

	$address_data[$result['address_id']] = array(
		'address_id'     => $result['address_id'],
		'firstname'      => $result['firstname'],
		'lastname'       => $result['lastname'],
		'company'        => $result['company'],
		'company_id'     => $result['company_id'],
		'tax_id'         => $result['tax_id'],				
		'address_1'      => $result['address_1'],
		'address_2'      => $result['address_2'],
		'postcode'       => $result['postcode'],
		'city'           => $result['city'],
		'zone_id'        => $result['zone_id'],
		'zone'           => $zone,
		'zone_code'      => $zone_code,
		'country_id'     => $result['country_id'],
		'country'        => $country,	
		'iso_code_2'     => $iso_code_2,
		'iso_code_3'     => $iso_code_3,
		'address_format' => $address_format
	);
}		

return $address_data;
public mixed getTotalAddresses ( )
Исходный код метода:
$query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "address WHERE customer_id = '" . (int)$this->customer->getId() . "'");

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

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

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

Комментарии