все сделал как было указано,
в файле relatedProducts.tpl.php заменил весь код на это---
1) <?php if( !defined( '_VALID_MOS' ) && !defined( '_JEXEC' ) ) die( 'Direct Access to '.basename(__FILE__).' is not allowed.' ); ?>
<hr/>
<h3><?php echo $VM_LANG->_('PHPSHOP_RELATED_PRODUCTS_HEADING')?></h3>
<table width="100%" align="center">
<tr>
<?php
while( $products->next_record() ) { ?>
<td valign="top">
<?php echo $ps_product->product_snapshot2( $products->f('product_sku') )?>
</td>
<?php
}
?>
</tr>
</table>
---
2) В файле ps_product.php после этих строчек ---
class vm_ps_product extends vmAbstractObject {
var $_key = 'product_id';
var $_table_name = '#__{vm}_product';
---
добавил вот этот код:---
function product_snapshot2( $product_sku, $show_price=true, $show_addtocart=true, $show_product_name = true ) {
global $sess, $mm_action_url;
$category_id = vmGet($_REQUEST, "category_id", null); /* Получаем категорию в которой находится товар */
/*Отбираем опубликованные продукты из данной категории*/
$product_name = vmGet($_REQUEST, "product_name", null); /* Получаем имя товара */
/*Отбираем опубликованные продукты с похожим именем*/
$q='SELECT product.`product_id` , `product_name`';
$s = $q.' FROM `#_{vm}_product`;
$q=$q.' WHERE product.`product_name` LIKE '%$product_name%';
$q=$q.' AND `product_publish` = "Y"';
$q=$q.' LIMIT 0 , 30';
$db = new ps_DB;
$db->query( $q );
require_once(CLASSPATH.'ps_product_category.php');
$ps_product_category = new ps_product_category;
/* $q = "SELECT product_id, product_name, product_parent_id, product_thumb_image FROM #__{vm}_product WHERE product_sku='$product_sku'"; */
$myres = $db->record;
foreach ($myres as $rplist){
// if ($myres->next_record()) {
$product_id = $db->f("product_id" );
$tpl = new $GLOBALS['VM_THEMECLASS']();
$cid = $ps_product_category->get_cid( $product_id );
$tpl->set( 'product_id', $product_id);
$tpl->set( 'product_name', $db->f("product_name") );
$tpl->set( 'show_product_name', $show_product_name );
if ($db->f("product_parent_id")) {
$url = "?page=shop.product_details&category_id=$cid&flypage=".$this->get_flypage($db->f("product_parent_id"));
$url .= "&product_id=" . $db->f("product_parent_id");
} else {
$url = "?page=shop.product_details&category_id=$cid&flypage=".$this->get_flypage($db->f("product_id"));
$url .= "&product_id=" . $db->f("product_id");
}
$product_link = $sess->url($mm_action_url. "index.php" . $url);
$tpl->set( 'product_link', $product_link );
$tpl->set( 'product_thumb_image', $db->f("product_thumb_image"), "alt=\"".$db->f("product_name")."\"");
if (_SHOW_PRICES == '1' && $show_price) {
// Show price, but without "including X% tax"
$price = $this->show_price( $db->f("product_id"), true );
$tpl->set( 'price', $price );
}
if (USE_AS_CATALOGUE != 1 && $show_addtocart
&& isset( $GLOBALS['product_info'][$product_id]['price']['product_price_id'] ) // Product must have a price to add it to cart
&& !$this->product_has_attributes($product_id, true) // Parent Products and Products with attributes can't be added to cart this way
) {
$url = "?page=shop.cart&func=cartAdd&product_id=" . $db->f("product_id");
$addtocart_link = $sess->url($mm_action_url. "index.php" . $url);
$tpl->set( 'addtocart_link', $addtocart_link );
}
return $tpl->fetch( 'common/productsnapshot.tpl.php');
}
return '';
}
---
Итог. В тех карточках товара где выводился уже список сопутствующих товаров выдается ошибка. А в тех карточках где не было сопутствующих товаров они так и не появились
З.Ы. немного синтаксис неправильный был тут:
---
$q='SELECT product.`product_id` , `product_name`';
$s = $q.' FROM `#_{vm}_product`;
$q=$q.' WHERE product.`product_name` LIKE '%$product_name%';
$q=$q.' AND `product_publish` = "Y"';
$q=$q.' LIMIT 0 , 30';
---
я поправил, но все равно результат ноль