OpenCart 🇺🇦

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

Тип Возвр. Описание
public mixed getFrequencies ( )
Исходный код метода:
return array(
	'day' => $this->language->get('text_day'),
	'week' => $this->language->get('text_week'),
	'semi_month' => $this->language->get('text_semi_month'),
	'month' => $this->language->get('text_month'),
	'year' => $this->language->get('text_year'),
);
public mixed getProfile ( $profile_id )
Исходный код метода:
return $this->db->query("SELECT * FROM `" . DB_PREFIX . "profile` WHERE profile_id = " . (int)$profile_id)->row;
public mixed getProfileDescription ( $profile_id )
Исходный код метода:
$profile_descriptions = array();

$results = $this->db->query("SELECT * FROM `" . DB_PREFIX . "profile_description` WHERE `profile_id` = " . (int)$profile_id . "
")->rows;

foreach ($results as $result) {
	$profile_descriptions[$result['language_id']] = array(
		'name' => $result['name'],
	);
}

return $profile_descriptions;
public mixed getProfiles ( )
Исходный код метода:
return $this->db->query("SELECT `p`.`profile_id`, `p`.`sort_order`, `pd`.`name` FROM `" . DB_PREFIX . "profile` AS `p` JOIN `" . DB_PREFIX . "profile_description` AS `pd` ON `pd`.`profile_id` = `p`.`profile_id` AND `pd`.`language_id` = " . (int)$this->config->get('config_language_id') . " ORDER BY p.sort_order ASC
")->rows;
public mixed addProfile ( $data )
Исходный код метода:
$this->db->query("INSERT INTO `" . DB_PREFIX . "profile` SET `sort_order` = " . (int)$data['sort_order'] . ", `status` = " . (int)$data['status'] . ", `price` = " . (double)$data['price'] . ", `frequency` = '" . $this->db->escape($data['frequency']) . "', `duration` = " . (int)$data['duration'] . ", `cycle` = " . (int)$data['cycle'] . ", `trial_status` = " . (int)$data['trial_status'] . ", `trial_price` = " . (double)$data['trial_price'] . ", `trial_frequency` = '" . $this->db->escape($data['trial_frequency']) . "', `trial_duration` = " . (int)$data['trial_duration'] . ", `trial_cycle` = " . (int)$data['trial_cycle']);

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

foreach ($data['profile_description'] as $language_id => $profile_description) {
	$this->db->query("INSERT INTO `" . DB_PREFIX . "profile_description` (`profile_id`, `language_id`, `name`) VALUES (" . (int)$profile_id . ", " . (int)$language_id. ", '" . $this->db->escape($profile_description['name']) . "')");
}

return $profile_id;
public mixed updateProfile ( $profile_id, $data )
Исходный код метода:
$this->db->query("DELETE FROM `" . DB_PREFIX . "profile_description` WHERE profile_id = " . (int)$profile_id);

$this->db->query("UPDATE `" . DB_PREFIX . "profile` SET `sort_order` = " . (int)$data['sort_order'] . ", `status` = " . (int)$data['status'] . ", `price` = " . (double)$data['price'] . ", `frequency` = '" . $this->db->escape($data['frequency']) . "', `duration` = " . (int)$data['duration'] . ", `cycle` = " . (int)$data['cycle'] . ", `trial_status` = " . (int)$data['trial_status'] . ", `trial_price` = " . (double)$data['trial_price'] . ", `trial_frequency` = '" . $this->db->escape($data['trial_frequency']) . "', `trial_duration` = " . (int)$data['trial_duration'] . ", `trial_cycle` = " . (int)$data['trial_cycle'] . " WHERE profile_id = " . (int)$profile_id);

foreach ($data['profile_description'] as $language_id => $profile_description) {
	$this->db->query("INSERT INTO `" . DB_PREFIX . "profile_description` (`profile_id`, `language_id`, `name`) VALUES (" . (int)$profile_id . ", " . (int)$language_id. ", '" . $this->db->escape($profile_description['name']) . "')");
}
public mixed deleteProfile ( $profile_id )
Исходный код метода:
$this->db->query("DELETE FROM `" . DB_PREFIX . "profile` WHERE profile_id = " . (int)$profile_id);
$this->db->query("DELETE FROM `" . DB_PREFIX . "profile_description` WHERE profile_id = " . (int)$profile_id);
$this->db->query("DELETE FROM `" . DB_PREFIX . "product_profile` WHERE profile_id = " . (int)$profile_id);

$this->db->query("UPDATE `" . DB_PREFIX . "order_recurring` SET `profile_id` = 0 WHERE `profile_id` = " . (int)$profile_id);
public mixed copyProfile ( $profile_id )
Исходный код метода:
$data = $this->getProfile($profile_id);
$data['profile_description'] = $this->getProfileDescription($profile_id);

foreach ($data['profile_description'] as &$profile_description) {
	$profile_description['name'] .= ' - 2';
}

$this->addProfile($data);

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

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

Комментарии