Добавление нового столбца в таблицу товаров админки OpenCart 2

Способ в статье рабочий, но редактировать исходные файлы в OcStore/OpenCart считается «костылем», гораздо правильней написать модификацию (OCmod) и установить стандартными средствами движка, возможно такие модификации уже существуют, поищите, в любом случае не забывайте делать backup!
Задача: в админ-панели OpenCart 2 (тестировалось на версии 2.0.3.1, но должно работать и в более новых 2.x, а также в ocStore 2.x) на странице Каталог->Товары добавить новый столбец в таблицу товаров. Пускай это будет уже предусмотренное в движке поле UPC.

1) Файл product_list.tpl (/admin/view/template/catalog/product_list.tpl)

В product_list.tpl формируется таблица со списком товаров. Начинаем с заголовка таблицы (thead). Пусть новый столбец будет выводиться после столбца "Статус", находим этот фрагмент кода:

<td class="text-left"><?php if ($sort == 'p.status') { ?>
<a href="<?php echo $sort_status; ?>" class="<?php echo strtolower($order); ?>"><?php echo $column_status; ?></a>
<?php } else { ?>
<a href="<?php echo $sort_status; ?>"><?php echo $column_status; ?></a>
<?php } ?></td>

Добавляем после него:

<td class="text-left"><?php if ($sort == 'p.upc') { ?>
<a href="<?php echo $sort_upc; ?>" class="<?php echo strtolower($order); ?>"><?php echo 'UPC'; ?></a>
<?php } else { ?>
<a href="<?php echo $sort_upc; ?>"><?php echo 'UPC'; ?></a>
<?php } ?></td>

То есть мы скопировали код вывода столбца "Статус" в шапке таблицы и вставили ниже, изменив p.upc вместо p.status, $sort_upc вместо $sort_status, а вместо "echo $column_status" написали 'echo UPC', иначе пришлось бы вносить изменения еще в языковой файл.

Теперь тело таблицы (tbody). Находим:

<td class="text-left"><?php echo $product['status']; ?></td>

Добавляем строку ниже:

<td class="text-left"><?php echo $product['upc']; ?></td>

Последнее мелкое изменение:

<td class="text-center" colspan="8"><?php echo $text_no_results; ?></td>

Изменяем colspan на 9, чтобы таблица не "ломалась", если товары не найдены.

Смотрим, что получилось:
Добавление столбца OpenCart

Столбец добавился, но внутри пока ничего не выводится. Если на сервере включено отображение предупреждений может быть так: "Notice: Undefined index: upc in [путь]/public_html/admin/view/template/catalog/product_list.tpl on line 255".

2) Файл product.php (/admin/controller/catalog/product.php)

Этот файл отвечает за вызов "model", обработку и подготовку полученных данных для вывода в "view".
Делаем поиск по sort_status, будет всего одна строчка. Дублируем и меняем на sort_upc, должно получиться так:

$data['sort_status'] = $this->url->link('catalog/product', 'token=' . $this->session->data['token'] . '&amp;amp;sort=p.status' . $url, 'SSL');
$data['sort_upc'] = $this->url->link('catalog/product', 'token=' . $this->session->data['token'] . '&amp;amp;sort=p.upc' . $url, 'SSL');

Затем находим массив $data['products'][] и после строки:

'status'     => ($result['status']) ? $this->language->get('text_enabled') : $this->language->get('text_disabled'),

добавляем:

'upc'		=> $result['upc'],

3) Файл product.php (/admin/model/catalog/product.php)

В этом файле формируются запросы к базе данных, которые затем используются в "controller". Нужно внести только одну изменение: находим массив $sort_data и добавляем p.upc, получится так:

$sort_data = array(
'pd.name',
'p.model',
'p.price',
'p.quantity',
'p.status',
'p.upc',
'p.sort_order'
);

Все работает:
Добавление столбца OpenCart
Если после этих действий ничего не заработало:

  • попробуйте очистить кэш на странице "Расширения"-"Модификаторы" (если магазин уже функционирует советую перед этим сделать резервную копию файлов и БД)
  • возможно, вы допустили ошибки в коде, проверьте логи в админ-панели или в файле /system/logs/error.log

Posted under: OpenCart

62 комментариев

  • Vlad (23.11.2020@15:36)

    Здравствуйте.
    В принципе все работает. Добавил колонку с stock_status_id
    Но:
    1. Выдает только значения из БД. Я так понимаю нужно языковой фаил поправлять?
    2. Не работает сортировка. Вылетает на страницу авторизации админпанели.

    • Dim565Vlad (23.11.2020@17:54)

      Здравствуйте.
      1) Не понял, какие значения из БД, можете описать подробней?
      2) Какая у вас версия движка? Постараюсь проверить

      • VladDim565 (24.11.2020@14:34)

        Версия движка ocStore 2.3.0.2.3
        С доработками, но они админку и БД не затрагивают.

        Параметр добавляемый в админку p.stock_status_id — отображает статус заказов. У меня в частности статус товаров с нулевым остатком.

        Произведенные изменения на примере добавления UPC
        Файл product_list.tpl (/admin/view/template/catalog/product_list.tpl)
        Добавлено

        <a href="» class=»»>

        <a href="»>

        Добавлено

        Изменено на 9

        Файл product.php (/admin/controller/catalog/product.php)
        Добавлено
        ‘stock_status_id’ => $result[‘stock_status_id’],
        Вот на сколько я понимаю как раз в этом месте и проблема. stock_status_id хранит в себе значение в цифрах статуса. А само наименование статуса хранится в другом месте. То есть код верно отрабатывает — выдает значение статуса. А хочется что бы выдавал наименование.

        Файл product.php (/admin/model/catalog/product.php)
        Добавлено
        ‘p.stock_status_id’,

        Все добавления делались как по инструкции.

        Можем связаться напрямую и обговорить момент доната.
        8 917 892 60 51 — Владислав
        Ватсап, телега.

        • ДенисVlad (01.01.2021@11:45)

          Скажите, а можно ли сделать так, чтобы можно было менять цену не заходя в карточку товара?

            • ДенисDim565 (02.01.2021@13:48)

              Спасибо за модуль, не думал что есть такой модуль. А еще вопрос, а можно ли аналогичным методом как вы писали в статье, вывести столбец с ценами со скидками от количества?

              • Dim565Денис (02.01.2021@14:45)

                Вы про цены из вкладки «Скидки» в карточке товара? Вывести можно, но думаю придется копировать дополнительные куски кода из контроллера product.php, похожий пример в моем комментарии от 24.11.2020@14:42, только у вас первая строчка похоже будет $product_discounts = $this->model_catalog_product->getProductDiscounts($this->request->get[‘product_id’]);

      • VladDim565 (24.11.2020@14:35)

        Коды половину срезались.
        Поэтому если ест желание и возможность, то контакт написал выше.

        • Dim565Vlad (24.11.2020@14:42)

          Да, здесь код режется, отправьте на info@dim565.ru

          Письмо получил, вышло сделать так:
          В /admin/controller/catalog/product.php после строки

          $product_total = $this->model_catalog_product->getTotalProducts($filter_data);

          Добавить

          function searchSubArray(Array $array, $key, $value) {  
              foreach ($array as $subarray){ 
                  if (isset($subarray[$key]) && $subarray[$key] == $value)
                    return $subarray;      
              }
          }
          $this->load->model('localisation/stock_status');
          $stock_statuses = $this->model_localisation_stock_status->getStockStatuses($filter_data);

          Ниже в массив добавить stock_status_id и stock_status_name:

          $data['products'][] = array(
                          'product_id' => $result['product_id'],
                          'image'      => $image,
                          'name'       => $result['name'],
                          'model'      => $result['model'],
                          'price'      => $result['price'],
                          'category'   => $category,
                          'special'    => $special,
                          'quantity'   => $result['quantity'],
                          'status'     => $result['status'] ? $this->language->get('text_enabled') : $this->language->get('text_disabled'),
                          'stock_status_id'       => $result['stock_status_id'],
                          'stock_status_name'       => searchSubArray($stock_statuses, "stock_status_id", $result['stock_status_id'])['name'],
                          'edit'       => $this->url->link('catalog/product/edit', 'token=' . $this->session->data['token'] . '&product_id=' . $result['product_id'] . $url, true)
                      );

          Теперь в файле tpl сможете выводить не только stock_status_id, а stock_status_name

  • Илья (21.04.2020@14:30)

    Добрый! А не у кого не выводится кракозябры. Хочу вывести статус у категорий, использую Opencart 3.0. на последнем этапе выводятся кракозябры, причем всей страницы. Не могу понять почему(((

    • Dim565Илья (21.04.2020@16:35)

      Здравствуйте, если кодировка слетает после правок возможно дело в текстовом редакторе, вы какой используете?

      И еще сегодня в статье заметил проблему с отображением кода, например было так

      &lt;td class="text-left"&gt;&lt;?php if ($sort == 'p.status') { ?&gt;

      Правильно так:

      <td class="text-left"><?php if ($sort == 'p.status') { ?>

      Уже исправил, но может вы копировали проблемный код?

  • Алекс (24.03.2020@18:59)

    Добрый день, извиняюсь за глупый вопрос, переименовать Артикул в ( Код товара ) и добавить столбик SKU в котором будет поиск по SKU-коду. Сделал как вы описали в статье, но даже столбик не появился.
    Версия: OPENCART.PRO 2.3.0.2.1
    Спасибо за внимание.

    • Dim565Алекс (24.03.2020@19:14)

      Здравствуйте. Если вы отредактировали файлы, но ничего не изменилось, то обычно дело в кэше. Попробуйте нажать кнопку «очистка» в админ-панели на странице Расширения-Модификаторы (если магазин уже функционирует советую перед этим сделать резервную копию файлов и БД)

  • Артур (21.08.2019@15:54)

    Добрый день!Opencart.PRO 2.3Сделал всё по инструкции столбец добавился,а вывода нет.
    2019-08-21 15:49:59 — PHP Notice: Undefined variable: sort_sku in /var/www/u0360859/data/www/elbinmotors.ru/admin/view/template/catalog/product_list.tpl on line 198

    2019-08-21 15:49:59 — PHP Notice: Use of undefined constant SKU — assumed ‘SKU’ in /var/www/u0360859/data/www/elbinmotors.ru/admin/view/template/catalog/product_list.tpl on line 198

    2019-08-21 15:49:59 — PHP Notice: Undefined index: sku in /var/www/u0360859/data/www/elbinmotors.ru/admin/view/template/catalog/product_list.tpl on line 239

    • Dim565Артур (21.08.2019@16:10)

      На Opencart.PRO не тестировал (до вашего комментария и не слышал о такой сборке), возможно код движка сильно отличается. Хотел проверить, но как понял PRO версия платная.

  • Дмитрий (24.06.2019@02:06)

    Здравствуйте, как сделали все таки вывод производителя? после этого:
    Перед строкой $data[‘products’][]
    Добавить
    $this->load->model(‘catalog/manufacturer’);
    $manufacturer_info = $this->model_catalog_manufacturer->getManufacturer($result[‘manufacturer_id’]);
    $manufacturer_name = $manufacturer_info[‘name’];

    А внутри массива $data[‘products’][] сделать так:
    ‘manufacturer’ => $manufacturer_name,

    как вывели во вьюхе?

    Notice: Undefined index: manufacturer_info in /system/storage/modification/admin/view/template/catalog/product_list.tpl on line 445

    • Dim565Дмитрий (29.06.2019@10:29)

      Здравствуйте. Прошу извинить за долгий ответ. Исходников не осталось, но думаю, выводить в view нужно так: echo $product[‘manufacturer’]. Проверьте, если не поможет напишите версию движка, проверю.

  • Александр (13.05.2019@22:06)

    Здравствуйте, есть ли возможность сделать тоже самое только вместо UPS добавить дату создания товара, заранее спасибо!

    • Dim565Александр (13.05.2019@22:36)

      Здравствуйте. Возможно, в БД дата создания хранится в поле date_added. Нужно смотреть, есть ли в «контроллере» получение информации из «модели», если нет, тогда придется редактировать довольно много файлов.

  • Павел (03.01.2019@13:30)

    Подскажите а как вывести в колонку атрибуты которые привязаны к товару, версия 2.3.Очень буду благодарен

    • Dim565Павел (03.01.2019@15:41)

      Вы хотите выводить только названия привязанных к товару атрибутов или еще и их значения?

      • ПавелDim565 (03.01.2019@19:45)

        канечно было бы хорошо вместе,но это если возможно,в противном случаии хотя бы название

        • Dim565Павел (03.01.2019@21:21)

          За эффективность/безопасность не отвечаю, но работает (проверял на OcStore 2.3.0.2.3).

          1. Файл product_list.tpl (/admin/view/template/catalog/product_list.tpl).
          1.1. Перед строкой:

          <td class="text-right"><?php echo $column_action; ?></td>

          Добавляете:

          <td class="text-left"><?php echo 'Атрибуты'; ?></a></td>

          1.2. После строки

          <td class="text-left"><?php echo $product['status']; ?></td>

          Добавляете:

          <td class="text-left">
          <?php foreach ($product['attributes'] as $product_attribute) { ?>
          <?php echo $product_attribute['attribute_name']; ?>
          =
          <?php echo $product_attribute['product_attribute_description'][1]['text']; //1 означает русскоязычное значение атрибута ?>
          <br />
          <?php } ?>
          </td>

          2. Файл product.php (/admin/controller/catalog/product.php)
          2.1. Перед массивом (~430 строка):

          $data['products'][] = array(

          Добавляете:

          $this->load->model('catalog/attribute');
          		$product_attributes = $this->model_catalog_product->getProductAttributes($result['product_id']);
          	$data['product_attributes'] = array(); // обнуляем массив от старых значений
          		foreach ($product_attributes as $product_attribute) {
          			$attribute_info = $this->model_catalog_attribute->getAttribute($product_attribute['attribute_id']);
          
          			if ($attribute_info) {
          				$data['product_attributes'][] = array(
          					'attribute_id'                  => $product_attribute['attribute_id'],
          					'attribute_name' => $attribute_info['name'],
          					'product_attribute_description' => $product_attribute['product_attribute_description']
          				);
          			}
          		}

          2.2. После строки:

          'quantity'   => $result['quantity'],

          Добавляете:

          'attributes' => $data['product_attributes'],
              • ПавелDim565 (04.01.2019@00:39)

                Скажите а можно вас попросить написать этот код с коментариями.Учусь по немногу

                $this->load->model(‘catalog/attribute’);
                $product_attributes = $this->model_catalog_product->getProductAttributes($result[‘product_id’]);
                $data[‘product_attributes’] = array(); // обнуляем массив от старых значений
                foreach ($product_attributes as $product_attribute) {
                $attribute_info = $this->model_catalog_attribute->getAttribute($product_attribute[‘attribute_id’]);

                if ($attribute_info) {
                $data[‘product_attributes’][] = array(
                ‘attribute_id’ => $product_attribute[‘attribute_id’],
                ‘attribute_name’ => $attribute_info[‘name’],
                ‘product_attribute_description’ => $product_attribute[‘product_attribute_description’]
                );
                }
                }

                • Dim565Павел (04.01.2019@10:12)

                  Напишу так, как я его понимаю.

                  $this->load->model('catalog/attribute'); // подключаем "модель" (для получения информации из БД), файл admin/model/catalog/attribute.php
                  $product_attributes = $this->model_catalog_product->getProductAttributes($result['product_id']); // в переменную product_attributes заносим все атрибуты для текущего товара (функция getProductAttributes находится в admin/model/catalog/product.php), если их нет получается пустой массив
                  $data['product_attributes'] = array(); // обнуляем массив data['product_attributes'] от старых значений (предыдущих товаров)
                  foreach ($product_attributes as $product_attribute) { // перебираем каждый элемент массива $product_attributes
                  $attribute_info = $this->model_catalog_attribute->getAttribute($product_attribute['attribute_id']); // в массив $attribute_info заносим название, значение атрибута и т.п по его id
                  
                  if ($attribute_info) { // если массив $attribute_info создался (такой атрибут существует), то заполняем массив $data['product_attributes'] (далее он будет перебираться в product_list.tpl)
                  $data['product_attributes'][] = array(
                  'attribute_id' => $product_attribute['attribute_id'],
                  'attribute_name' => $attribute_info['name'],
                  'product_attribute_description' => $product_attribute['product_attribute_description']
                  );
                  }
                  }
                  
  • Николай (05.11.2018@19:21)

    Версия ocStore 2.1.0.2.1
    Сделал пункт 1 но столбец ( пустой ) не отобразился

Добавить комментарий

Ваш e-mail не будет опубликован.