Перейти к содержанию
dimamix

Ограничение кол-ва атрибутов на странице категории

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

Добрый вечер, коллеги!

 

Прошу помочь решить одну задачу:

Вывел атрибуты в описания товаров на страницу категории.

Строка в контроллере выглядит следующим образом:

'attribute_groups' => $this->model_catalog_product->getProductAttributes($result['product_id']),

Как  можно её дополнить, чтобы выводилось только 9 атрибутов, а не все?

Или просьба подсказать другие варианты решения.. Заранее спасибо!

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


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

Почему именно 9?) И чего Вы этим хотите в итоге добиться?

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


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

Неторые товары сожержат по 10-20 характеристик. Мы xотим вывести не более 8-9 строк, показать ключевые характеристики товара. Остальные уже в карточке товара. Может сделаем меньше 8. Главное научиться ограничивать. В атрибутах проставлен порядок сортировки, сначала выводятся ключевые.

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


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

Коллеги, все еще актуально. Прошу помочь :-)

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


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

Решено другим способом. В css прописал для нужного блока:

	height: 160px;
	overflow: hidden;

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


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

dimamix, попробуйте поковырять в catalog/model/catalog/product.php

Изменения касаются переменной $iter.

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");
			
			$iter=0;
			foreach ($product_attribute_query->rows as $product_attribute) {
				$iter++;
				if ($iter>8) break;
				$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;
	}

Только скорее всего вам понадобится сделать копию функции getProductAttributes, внести в нее изменения, переименовать копию и обращаться к этой копии со страницы категорий.

И подойдет этот вариант только если группа аттрибутов одна, в противном случае, в каждой группе категорий будет выводится указанное в этой строке "if ($iter>8) break;" количество аттрибутов.

  • +1 1

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


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

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

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

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

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

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

Войти

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

Войти

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

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

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.