Jump to content
Rubik

Адаптация модуля под OpenCart 3.x

Recommended Posts

Доброе время суток. Подскажите пж хочу адаптировать модуль "Добавляем сортировку товаров по дате в админке Opencart 2.x" под  OpenCart 3.x контакты автора найти не удалось.

 

Код модуля под OpenCart 2

Спойлер

<modification>
    <name>Добавляет сортировку товаров по дате в админке</name>
    <version>1.0</version>
    <link>https://opencartmaster.ru</link>
    <author>Артем Шведов</author>
    <code>sort-date-admin</code>
 
    <file path="admin/controller/catalog/product.php">
        <operation>
            <search><![CDATA[protected function getList() {]]></search>
            <add position="after"><![CDATA[if (isset($this->request->get['filter_date_added'])) {
                  $filter_date = $this->request->get['filter_date_added'];
                      } else {
                            $filter_date = null;
                      }
             ]]></add>
        </operation>
        <operation>
            <search><![CDATA['filter_status'   => $filter_status,]]></search>
            <add position="after"><![CDATA['filter_date'     => $filter_date,
           ]]></add>
        </operation>
        <operation>
            <search><![CDATA[
              'status'     => $result['status'] ? $this->language->get('text_enabled') : $this->language->get('text_disabled'),
              ]]></search>
            <add position="after"><![CDATA[
                  'date_added' => $result['date_added'],
             ]]></add>
        </operation>
        <operation>
            <search><![CDATA[ $data['breadcrumbs'] = array();]]></search>
            <add position="before" index="1"><![CDATA[                        
                    if (isset($this->request->get['filter_date_added'])) {
                        $url .= '&filter_date_added=' . $this->request->get['filter_date_added'];
                    }
                ]]></add>
        </operation>
    </file>    
 
    <file path="admin/model/catalog/product.php">
        <operation>
            <search><![CDATA[$sql = "SELECT * FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id)";]]></search>
            <add position="after"><![CDATA[if (isset($data['filter_date_added']) && !is_null($data['filter_date_added'])) {
                      $sql .= " ORDER BY p.date_added '" . (int)$data['filter_date_added'] . "'";
                     }
               ]]></add>
        </operation>
        <operation>
            <search><![CDATA['p.sort_order']]></search>
            <add position="before"><![CDATA[
                'p.date_added',
             ]]></add>
        </operation>
    </file>
 
    <file path="admin/view/template/catalog/product_list.tpl">
        <operation>
            <search><![CDATA[<td class="text-right"><?php echo $column_action; ?></td>]]></search>
            <add position="before"><![CDATA[
                <td class="text-left">
                    <a href="<?php echo $sort_status.'&sort=p.date_added'; ?>">Дата </a>
                </td>
            ]]></add>
        </operation>
        <operation>
            <search><![CDATA[<td class="text-right"><a href="<?php echo $product['edit']; ?>" data-toggle="tooltip" title="<?php echo $button_edit; ?>" class="btn btn-primary"><i class="fa fa-pencil"></i></a></td>]]></search>
            <add position="before"><![CDATA[ 
                    <td class="text-left"><?php echo $product['date_added']; ?></td>
              ]]></add>
        </operation>
        <operation>
            <search><![CDATA[<button type="button" id="button-filter" class="btn btn-primary pull-right"><i class="fa fa-search"></i> <?php echo $button_filter; ?></button>]]></search>
            <add position="before"><![CDATA[<td class="center">&nbsp</td>]]></add>
        </operation>
    </file>
 
</modification>

 

Ошибка вот этого куска кода https://prnt.sc/p49m7w

Спойлер

if (isset($data['filter_date_added']) && !is_null($data['filter_date_added'])) {
                      $sql .= " ORDER BY p.date_added '" . (int)$data['filter_date_added'] . "'";
                     }

 

Ошибка в этой части кода

Спойлер

<file path="admin/model/catalog/product.php">
    <operation>
        <search><![CDATA[$sql = "SELECT * FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "'";]]></search>
        <add position="after"><![CDATA[if (isset($data['filter_date_added']) && !is_null($data['filter_date_added'])) {
                  $sql .= " ORDER BY p.date_added '" . (int)$data['filter_date_added'] . "'";
                 }]]>
        </add>
    </operation>

 

Спасибо!

Share this post


Link to post
Share on other sites
2 часа назад, Rubik сказал:

Ошибка вот этого куска кода 

Скорей всего вы его не туда "прилепили"

У вас ощ\шибка вылезла на шаблоне, а этого не должно быть

Share this post


Link to post
Share on other sites

Эту проблему решил.

Не подскажите как добавить ссылку на сортировку по дате

 

Вот так работает сортировка по статусу

Спойлер

<td class="text-left">{% if sort == 'p.status' %} <a href="{{ sort_status }}" class="{{ order|lower }}">{{ column_status }}</a> {% else %} <a href="{{ sort_status }}">{{ column_status }}</a> {% endif %}</td>

 

Сортировка по дате p.date_added но ссылка на главную страницу

Спойлер

<td class="text-right">{% if sort == 'p.date_added' %} <a href="{{ sort_p.date_added }}" class="{{ order|lower }}">{{ column_date }}</a> {% else %} <a href="{{ sort_p.date_added }}">{{ column_date }}</a> {% endif %}</td>

 

Share this post


Link to post
Share on other sites

Спасибо решено тему можно закрыть.

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
You are posting as a guest. If you have an account, please sign in.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Recently Browsing   0 members

    No registered users viewing this page.

×

Important Information

On our site, cookies are used and personal data is processed to improve the user interface. To find out what and what personal data we are processing, please go to the link. If you click "I agree," it means that you understand and accept all the conditions specified in this Privacy Notice.