Как показать второе изображение товара? PrestaShop 1.7.5.1 - PullRequest
1 голос
/ 23 мая 2019

Мне нужно показать другое изображение обложки (второе или последнее, это не важно, все, но не первое) только для определенного блока: ps_bestseller.

Единственное, что я нашелэтот код был ссылка , но он работает только для версии 1.6:

Это мой код по умолчанию:

{block name='product_thumbnail'}

    {if $product.cover}

      <a href="{$product.url}" class="thumbnail product-thumbnail">
        <img
          src = "{$product.cover.bySize.home_default.url}"
          alt = "{if !empty($product.cover.legend)}{$product.cover.legend}{else}{$product.name|truncate:30:'...'}{/if}"
          data-full-size-image-url = "{$product.cover.large.url}"
        >
      </a>
    {else}
      <a href="{$product.url}" class="thumbnail product-thumbnail">
        <img
          src = "{$urls.no_picture_image.bySize.home_default.url}"
        >
      </a>
    {/if}
  {/block}

Когда я пытаюсь редактировать кодон возвращает пустую страницу.Любое предложение?

1 Ответ

1 голос
/ 23 мая 2019

Создайте файл переопределения с именем Link.php в override/classes/ с таким содержанием:

<?php
use PrestaShop\PrestaShop\Core\Addon\Module\ModuleManagerBuilder;
use PrestaShop\PrestaShop\Adapter\SymfonyContainer;
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
use PrestaShop\PrestaShop\Core\Feature\TokenInUrls;

class Link extends LinkCore
{
    public function getLastImageLink($id_product, $product_name, $type = null) {
        $maxId = Db::getInstance()->getValue('SELECT id_image FROM `'._DB_PREFIX_.'image` WHERE id_product = '.(int)$id_product.'  ORDER BY position DESC');
        return $this->getImageLink($product_name, $id_product.'-'.$maxId, $type = null);
    }
}

Ensuite dans le tpl за апплет

{$link->getLastImageLink($product.id, $product.name, 'large')}

Привет

...