khryshchuk

Вывод атрибутов

Рекомендуемые сообщения

khryshchuk    0

Как можно вывести атрибуты товара в корзине? Если возможно, то интересует даже не все атрибуты, а по определеному ID-атрибута.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
khryshchuk    0

Все. Вопрос решил.

В /catalog/controller/checkout/cart.php добавил:

  public function getProductAttributes($product_id) {
		$product_attribute_group_data = array();

		$product_attribute_group_query = $this->db->query("SELECT ag.attribute_group_id, agd.name FROM " . DB_PREFIX . "product_attribute pa LEFT JOIN " . DB_PREFIX . "attribute a ON (pa.attribute_id = a.attribute_id) LEFT JOIN " . DB_PREFIX . "attribute_group ag ON (a.attribute_group_id = ag.attribute_group_id) LEFT JOIN " . DB_PREFIX . "attribute_group_description agd ON (ag.attribute_group_id = agd.attribute_group_id) WHERE pa.product_id = '" . (int)$product_id . "' AND agd.language_id = '" . (int)$this->config->get('config_language_id') . "' GROUP BY ag.attribute_group_id ORDER BY ag.sort_order, agd.name");

		foreach ($product_attribute_group_query->rows as $product_attribute_group) {
			$product_attribute_data = array();

			$product_attribute_query = $this->db->query("SELECT a.attribute_id, ad.name, pa.text FROM " . DB_PREFIX . "product_attribute pa LEFT JOIN " . DB_PREFIX . "attribute a ON (pa.attribute_id = a.attribute_id) LEFT JOIN " . DB_PREFIX . "attribute_description ad ON (a.attribute_id = ad.attribute_id) WHERE pa.product_id = '" . (int)$product_id . "' AND a.attribute_group_id = '" . (int)$product_attribute_group['attribute_group_id'] . "' AND ad.language_id = '" . (int)$this->config->get('config_language_id') . "' AND pa.language_id = '" . (int)$this->config->get('config_language_id') . "' ORDER BY a.sort_order, ad.name");

			foreach ($product_attribute_query->rows as $product_attribute) {
				$product_attribute_data[] = array(
					'attribute_id' => $product_attribute['attribute_id'],
					'name'         => $product_attribute['name'],
					'text'         => $product_attribute['text']
				);
			}

			$product_attribute_group_data[] = array(
				'attribute_group_id' => $product_attribute_group['attribute_group_id'],
				'name'               => $product_attribute_group['name'],
				'attribute'          => $product_attribute_data
			);
		}

		return $product_attribute_group_data;
	}

Здесь же добавил параметр для $data['products'][]

'attrib'      => $this->getProductAttributes($product['product_id'])

Ну и в /catalog/view/theme/default/template/checkout/cart.tpl в нужном месте вывел результат:

<?php
  $attr = $product['attrib'];
  print_r($attr[0]['attribute'][0]['text']);
?>

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Trener    0

А как вывести только нужный атрибут по ID ?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
deim    241

А как вывести только нужный атрибут по ID ?

просто добавить 

if ($product_attribute['attribute_id'] == 'id_атрибута')

?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Trener    0

просто добавить 

if ($product_attribute['attribute_id'] == 'id_атрибута')

?

 

Что то потыкал в разные места и не получилось. Может не туда тыкаю или неправильно. Можете поточнее направить, если не трудно

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти


  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу