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

Задача: в админ-панели 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 выводится таблица с товарами. Через просмотр кода элемента в браузере узнаем класс таблицы: table table-bordered table-hover. В файле product_list находим нужное место. Решаем, где именно будет располагаться новый столбец. Пускай он будет после столбца "Статус".

Начинаем с заголовка таблицы (thead). Копируем кусок кода с выводом статуса, вставляем ниже и меняем имена: вместо p.status будет p.upc, вместо $sort_status пишем $sort_upc, а вместо $column_status напишем имя поля 'UPC', чтобы не вносить изменения в языковой файл:

<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>

Теперь тело таблицы (tbody):

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

И еще мелкое изменение:

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

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

Смотрим, что получилось:
Добавление столбца OpenCart
Столбец добавился, но естественно в нем пока ничего не выводится.

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

Делаем поиск по sort_status, будет всего одна строчка. Дублируем и меняем на sort_upc:

$data['sort_status'] = $this->url->link('catalog/product', 'token=' . $this->session->data['token'] . '&sort=p.status' . $url, 'SSL');
$data['sort_upc'] = $this->url->link('catalog/product', 'token=' . $this->session->data['token'] . '&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)

Находим массив $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

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

  • Павел (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 но столбец ( пустой ) не отобразился

  • Дмитрий (07.09.2018@23:26)

    Добрый день. А как добавить в админку столбец с датой редактирования товара? Opencart 2.3

      • ДмитрийDim565 (08.09.2018@10:13)

        Notice: Undefined index: date_modified in ….view/template/catalog/product_list.tpl on line 166
        166 строка:
        Подскажите, пожалуйста

        • ДмитрийДмитрий (08.09.2018@10:15)

          td class=»text-left»

          ?php echo $product[‘date_modified’]; ?

          /td

          треугольные скобки есть, естественно. Просто так не добавляет

                • ДмитрийDim565 (08.09.2018@12:15)

                  Это я голова два уха. Кэш модификатора не почистил… Спасибо огромное. Вы очень крутой мега мозг) Крутые штучки подсказываете.

                • ДмитрийDim565 (08.09.2018@12:25)

                  Теперь есть вопрос.. После чистки кэша стало всё ок, а затем проблема возникла:
                  Warning: Division by zero in …/system/storage/modification/admin/controller/common/column_left.php on line 1124

                  Строка 1124 такая: $data[‘other_status’] = round(($other_total / $order_total) * 100);

                  Везде всё стало мега крупным в админке.

                • ДмитрийDim565 (08.09.2018@12:39)

                  Проблема в общем такая — эта ошибка вылазит только в одном случае, когда я удаляю все заказы. Так что не страшно.. Спасибо!

  • Олег (06.09.2018@14:25)

    Добрый день. Именно с UPC все стало на 2.3 как и описано. Сейчас мучаюсь с проблемой сделать вместо UPC — Производителя. Я так понял, что там немного различается метод интегрирования, т.к. там помимо значения идет еще и идентификатор, поєтому відает ошибки в выдаче. Не подскажете как правильно прописать Производителя вместо UPC?

    • Dim565Олег (06.09.2018@14:29)

      Здравствуйте. Давно не работал с OpenCart, нет возможности проверить у себя. Какие ошибки?

      • ОлегDim565 (06.09.2018@14:46)

        Notice: Undefined index: manufacturer /admin/controller/catalog/product.php
        Это я прописал везде, где у вас написано UPC — manufacturer

          • ОлегDim565 (06.09.2018@14:49)

            Opencart 2.3.0.2
            Ругается на строчку:
            ‘manufacturer’ => $result[‘manufacturer’],
            в блоке $data[‘products’][] = array(
            в /admin/controller/catalog/product.php

            • Dim565Олег (06.09.2018@15:39)

              Да, в таблице products нет названия производителя, а только его id.

              Нужно изменить файл /admin/controller/catalog/product.php

              Перед строкой $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,

              Проверьте, должно показывать производителя. И мне кажется неправильно подключать $this->load->model(‘catalog/manufacturer’) во второй раз (ниже по коду он тоже используется), но других идей нет.

Добавить комментарий для Николай Отменить ответ

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