[VQMOD] Title em categorias e products
Enviado: 04 Out 2012, 12:45
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:
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"
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
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