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

Прикрутить id категории к ссылке из карусели

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

	private function getProducts( $results, $setting ){
		$products = array();
		foreach ($results as $result) {
			if ($result['image']) {
				$image = $this->model_tool_image->resize($result['image'], $setting['width'], $setting['height']);
			} else {
				$image = false;
			}
						
			if (($this->config->get('config_customer_price') && $this->customer->isLogged()) || !$this->config->get('config_customer_price')) {
				$price = $this->currency->format($this->tax->calculate($result['price'], $result['tax_class_id'], $this->config->get('config_tax')));
			} else {
				$price = false;
			}
					
			if ((float)$result['special']) {
				$special = $this->currency->format($this->tax->calculate($result['special'], $result['tax_class_id'], $this->config->get('config_tax')));
			} else {
				$special = false;
			}
			
			if ($this->config->get('config_review_status')) {
				$rating = $result['rating'];
			} else {
				$rating = false;
			}
			 
			$products[] = array(
				'product_id' => $result['product_id'],
				'thumb'   	 => $image,
				'name'    	 => $result['name'],
				'price'   	 => $price,
				'special' 	 => $special,
				'rating'     => $rating,
				'description'=> (html_entity_decode($result['description'], ENT_QUOTES, 'UTF-8')),
				'reviews'    => sprintf($this->language->get('text_reviews'), (int)$result['reviews']),
				'href'    	 => $this->url->link('product/product', 'product_id=' . $result['product_id']),
			);
		}
		return $products;
	}
}

Хочется добиться 

'href'        => $this->url->link('product/product', 'path=' . $this->request->get['path'] . '&product_id=' . $result['product_id'])

Но никак не могу понять, как прикрутить переменную path

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


Ссылка на сообщение
Поделиться на другие сайты
$check_cat = $this->checkCat($result['product_id']);

if ($check_cat) {
 $path = $check_cat;
} else {
 $path = 0;
}

...


'href'        => $this->url->link('product/product', 'path=' . (int)$path . '&product_id=' . $result['product_id'])


private function checkCat($product_id) {
	$product_id = (int)$product_id;
	if ($product_id < 1) return false;

	static $path = null;
	if (!is_array($path)) {
		$path = $this->cache->get('product.seopath');
		if (!is_array($path)) $path = array();
	}

	if (!isset($path[$product_id])) {
		$query = $this->db->query("SELECT category_id FROM " . DB_PREFIX . "product_to_category WHERE product_id = '" . $product_id . "' ORDER BY main_category DESC LIMIT 1");

		$path[$product_id] = $this->getPathByCategory($query->num_rows ? (int)$query->row['category_id'] : 0);

		$this->cache->set('product.seopath', $path);
		}

	return $path[$product_id];
}

private function getPathByCategory($category_id) {
	$category_id = (int)$category_id;
	if ($category_id < 1) return false;

	static $path = null;
	if (!is_array($path)) {
		$path = $this->cache->get('category.seopath');
		if (!is_array($path)) $path = array();
	}

	if (!isset($path[$category_id])) {
		$max_level = 10;

		$sql = "SELECT CONCAT_WS('_'";
		for ($i = $max_level-1; $i >= 0; --$i) {
			$sql .= ",t$i.category_id";
		}
		$sql .= ") AS path FROM " . DB_PREFIX . "category t0";
		for ($i = 1; $i < $max_level; ++$i) {
			$sql .= " LEFT JOIN " . DB_PREFIX . "category t$i ON (t$i.category_id = t" . ($i-1) . ".parent_id)";
			}
		$sql .= " WHERE t0.category_id = '" . $category_id . "'";

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

		$path[$category_id] = $query->num_rows ? $query->row['path'] : false;

		$this->cache->set('category.seopath', $path);
	}

	return $path[$category_id];
}

как то так...

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


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

тут реализовано, для модуля вывода товаров из определенной категории

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


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

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

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

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

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

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

Войти

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

Войти

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

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

×

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

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