Página 1 de 1

[VQMOD] Title em categorias e products

Enviado: 04 Out 2012, 12:45
por vipersbr
Galera tudo bem?? Seguinte... eu preciso de ajuda de alguém que entenda dos códigos PHP do OC

Estou criando um vqmod que add um tag title nos produtos. E estou quase lá!

preciso fazer com que uma variável do arquivo "/catalog/controller/module/latest.php" converse com "admin/model/catalog/product.php"

Como funciona e do que preciso??

No arquivo "latest.php" temos:
<?php
class ControllerModuleLatest extends Controller {
protected function index($setting) {
$this->language->load('module/latest');

$this->data['heading_title'] = $this->language->get('heading_title');

$this->data['button_cart'] = $this->language->get('button_cart');

$this->load->model('catalog/product');

$this->load->model('tool/image');

$this->data['products'] = array();

$data = array(
'sort' => 'p.date_added',
'order' => 'DESC',
'start' => 0,
'limit' => $setting['limit']
);

$results = $this->model_catalog_product->getProducts($data);

foreach ($results as $result) {
if ($result['image']) {
$image = $this->model_tool_image->resize($result['image'], $setting['image_width'], $setting['image_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;
}

$this->data['products'][] = array(
'product_id' => $result['product_id'],
'thumb' => $image,
'name' => $result['name'],
'cttitle' => $result['cttitle'],
'price' => $price,
'special' => $special,
'rating' => $rating,
'reviews' => sprintf($this->language->get('text_reviews'), (int)$result['reviews']),
'href' => $this->url->link('product/product', 'product_id=' . $result['product_id']),
);


}

if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/module/latest.tpl')) {
$this->template = $this->config->get('config_template') . '/template/module/latest.tpl';
} else {
$this->template = 'default/template/module/latest.tpl';
}

$this->render();
}
}
?>

Como vocês podem ver nessa linha em negrito e sublinhada, essa é a variável que está buscando o "cttitle" no meu banco. Só que todo esse arquivo "latest.php" está buscando as informações no arquivo "product.php" em ">getProducts" então está dando erro nessa linha porque o resultado é falho.. não encontra nada!

Vejam o arquivo "product.php"
[...]
public function getProductsByCategoryId($category_id) {
$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_category p2c ON (p.product_id = p2c.product_id) WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p2c.category_id = '" . (int)$category_id . "' ORDER BY pd.name ASC");

return $query->rows;
}

public function getProductDescriptions($product_id) {
$product_description_data = array();

$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_description WHERE product_id = '" . (int)$product_id . "'");

foreach ($query->rows as $result) {
$product_description_data[$result['language_id']] = array(
'name' => $result['name'],
'cttitle' => $result['cttitle'],
'description' => $result['description'],
'meta_keyword' => $result['meta_keyword'],
'meta_description' => $result['meta_description'],
'tag' => $result['tag']
);
}

return $product_description_data;
}
[...]

Como vocês também podem ver, nesse arquivo "product.php" a variável "cttitle" que o arquivo "latest.php" está buscando não fica em "getProduct" e sim na parte em negrito "getProductDescriptions".

Minha dúvida é: qual comando eu executo ou qual código eu coloco no "latest.php" para que ele consiga achar e apresentar o resultado de "cttitle" buscado em "getProductDescriptions" do "product.php"

bem é isso pessoal! agradeço a quem puder ajudar e assim que ficar pronto disponibilizo para galera

abraço

Re: [VQMOD] Title em categorias e products

Enviado: 05 Out 2012, 08:07
por maikorodrigo
Bom dia amigo,

Se vc colocar a varíavel 'cttitle' => $result['cttitle'], dentro da function getProducts creio que deva funcionar. Talves terá que adaptar o SQL para ele buscar no campo que vc quer pegar o valor.

Abraços.

Re: [VQMOD] Title em categorias e products

Enviado: 05 Out 2012, 09:16
por vipersbr
nao deu certo não amigo... que porre hahaha

vlw pela ajuda!

Re: [VQMOD] Title em categorias e products

Enviado: 05 Out 2012, 10:50
por vipersbr
galera me ajudem.. estou quase lá! consegui fazer com que as tags apareçam!

no latest.php eu editei a linha:
$results = $this->model_catalog_product->getProducts($data);
para
$results = $this->model_catalog_product->getProducts(0);
porem quando abre minha loja: www.grifin.com.br

da o erro:
Warning: http_build_query() [function.http-build-query]: Parameter 1 expected to be Array or Object. Incorrect value given in /home/grifin/public_html/vqmod/vqcache/vq2-catalog_model_catalog_product.php on line 73
Na linha 73 temos:
$cache = md5(http_build_query($data));

$product_data = $this->cache->get('product.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$customer_group_id . '.' . $cache);
alguém poderia dar uma força?