Модуль MegaFilterPRO 2.0.5.2 (NULL) MFPLUS 1.2.3 OCMod OC2.X

Тема в разделе "Opencart 2", создана пользователем TryCatch, 18 мар 2017.

Метки:
Информация :
Внимание форумчане! При создании тем, или выкладывании какой-либо информации проверьте в какой ветке форума вы находитесь! Не путайте Opencart и Opencart2. При несоблюдении данного условия выносится соответствующее наказание! И потом не говорите что вас НЕ ПРЕДУПРЕЖДАЛИ! По возможности используйте обменники mail, yandex, google, dropbox, rghost Дабы избежать просьб перезалить и проблем с рекламой!
Постинг нескольких постов подряд приравнивается к НАРУШЕНИЮ! Будьте вежливы и соблюдайте правила ;-)
  1. TryCatch

    TryCatch

    Регистр.:
    19 авг 2016
    Сообщения:
    185
    Симпатии:
    76
    [​IMG]
    Продажник: ссылка
    Поддерживаемые версии Оpencart: 2.0.0.0, 2.0.1.0, 2.0.1.1, 2.0.2.0, 2.0.3.1, 2.1.0.1, 2.1.0.2, 2.2.0.0, 2.3.0.0, 2.3.0.1, 2.3.0.2, 2.0.0.0, 2.0.1.0, 2.0.1.1, 2.0.2.0, 2.0.3.1, 2.1.0.1, 2.1.0.2, 2.2.0.0, 2.3.0.0, 2.3.0.1, 2.3.0.2, 2.0.1.0, 2.0.1.1, 2.0.2.0, 2.0.3.1, 2.1.0.1, 2.1.0.2, 2.2.0.0, 2.3.0.0, 2.3.0.1, 2.3.0.2
    Архив содержит:
    Mega Filter PRO 2.0.5.2 (NULL);
    Mega Filter PLUS 1.2.3;
    languagepack-russianv 2_0_8;

    Полный NULL, все проверки были удалены.
    Проблем с работоспособностью не обнаружено.
    При активации ввести любые данные.

     
    Последнее редактирование: 15 май 2017
    DreamClassic, sidoruk2000, Stealth421 и 12 другим нравится это.
  2. ITmaestro

    ITmaestro Писатель

    Регистр.:
    8 июл 2015
    Сообщения:
    1
    Симпатии:
    0
    Кто-нибудь тестировал? После установки на 2.3 и обновления модификаторов в модулях, сайт не работает, работает только админка. Пробовал несколько раз переустановить несколькими способами(включая способ который указан в инструкции, строго по пунктам) результат 1. Сайт не работает(внешняя часть), админка работает.
     
  3. TryCatch

    TryCatch

    Регистр.:
    19 авг 2016
    Сообщения:
    185
    Симпатии:
    76
    Могу утверждать только за версию выложенную в этой теме. Тестировал на 2.3 все было хорошо, и не только у меня. Смотрите лог модификатора, может он конфликтует с чем то.
     
  4. richv

    richv Писатель

    Регистр.:
    20 авг 2011
    Сообщения:
    4
    Симпатии:
    0
    ребята, есть мод под unishop ?
     
  5. nloshka

    nloshka

    Регистр.:
    25 май 2012
    Сообщения:
    243
    Симпатии:
    210
    Ставлю этот мод вывод фильтров хороший все опции какие нужны выводятся.
    но при применении любой опции фильтра получаю ошибку:
    Код:
     Fatal error: Uncaught exception 'Exception' with message 'Error: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'INNER JOIN `oc_product_to_store` AS `p2s` ON `p2s`.`product_id` = ' at line 2<br />Error No: 1064<br />SELECT COUNT(DISTINCT `product_id`) AS `total` FROM( INNER JOIN `oc_product_to_store` AS `p2s` ON `p2s`.`product_id` = `p`.`product_id` AND `p2s`.`store_id` = 0 INNER JOIN `oc_product_to_category` AS `p2c` ON `p2c`.`product_id` = `p`.`product_id` INNER JOIN `oc_category_path` AS `cp` ON `cp`.`category_id` = `p2c`.`category_id` SELECT COUNT(*) AS total FROM ( SELECT p.product_id, p.sort_order, "1" AS match_filters FROM `oc_product` AS p INNER JOIN `oc_product_to_store` AS p2s ON (p2s.product_id = p.product_id) INNER JOIN `oc_bf_filter` AS f ON (p.product_id = f.product_id) INNER JOIN `oc_product_to_category` AS p2c ON (p.product_id = p2c.product_id) INNER in /home/drvt/public_html/mystore/system/library/db/mysqli.php on line 40
    Всё остальное работает норм.
    Версия ocStore 2.3.0.2
     
  6. TryCatch

    TryCatch

    Регистр.:
    19 авг 2016
    Сообщения:
    185
    Симпатии:
    76
    Залогируйте запрос.
    В файле system\storage\modification\catalog\model\catalog\product.php
    В методе getProducts()
    Перед строкой:
    PHP:
    $query $this->db->query($sql);
    Вставьте:
    PHP:
    $this->log->write($sql);
    Повторите ваши действия и запрос выложите в теме.
     
  7. nloshka

    nloshka

    Регистр.:
    25 май 2012
    Сообщения:
    243
    Симпатии:
    210
    Код:
    2017-04-25 18:41:22 -  SELECT p.product_id, p.sort_order, "1" AS match_filters, pp.sort_order FROM `oc_product` AS p INNER JOIN `oc_product_to_store` AS p2s ON (p2s.product_id = p.product_id) INNER JOIN `oc_bf_filter` AS f ON (p.product_id = f.product_id) INNER JOIN `oc_product_to_category` AS p2c ON (p.product_id = p2c.product_id) INNER JOIN `oc_category_path` AS cp ON (cp.category_id = p2c.category_id) INNER JOIN `oc_product_description` AS pd ON (pd.product_id = p.product_id) INNER JOIN `oc_product` AS pp ON (pp.product_id = p.product_id) WHERE p2s.store_id = '0' AND cp.path_id = '115' AND f.out_of_stock = 0 AND pd.language_id = '1' GROUP BY p.product_id HAVING match_filters = 1 ORDER BY pp.sort_order ASC, pd.name ASC LIMIT 0, 15
    2017-04-25 18:41:22 - PHP Notice:  Undefined index: status in /home/drvt/public_html/mystore/system/storage/modification/catalog/controller/common/column_left.php on line 95
    2017-04-25 18:41:22 - PHP Notice:  Undefined index: status in /home/drvt/public_html/mystore/system/storage/modification/catalog/controller/common/content_top.php on line 95
    2017-04-25 18:42:30 -  SELECT p.product_id, p.sort_order, "1" AS match_filters, pp.sort_order FROM `oc_product` AS p INNER JOIN `oc_product_to_store` AS p2s ON (p2s.product_id = p.product_id) INNER JOIN `oc_bf_filter` AS f ON (p.product_id = f.product_id) INNER JOIN `oc_product_to_category` AS p2c ON (p.product_id = p2c.product_id) INNER JOIN `oc_category_path` AS cp ON (cp.category_id = p2c.category_id) INNER JOIN `oc_product_description` AS pd ON (pd.product_id = p.product_id) INNER JOIN `oc_product` AS pp ON (pp.product_id = p.product_id) WHERE p2s.store_id = '0' AND cp.path_id = '115' AND f.out_of_stock = 0 AND pd.language_id = '1' GROUP BY p.product_id HAVING match_filters = 1 ORDER BY pp.sort_order ASC, pd.name ASC LIMIT 0, 15
    2017-04-25 18:42:30 - PHP Notice:  Undefined index: status in /home/drvt/public_html/mystore/system/storage/modification/catalog/controller/common/column_left.php on line 95
    2017-04-25 18:42:30 - PHP Notice:  Undefined index: status in /home/drvt/public_html/mystore/system/storage/modification/catalog/controller/common/content_top.php on line 95
    2017-04-25 18:42:42 -  SELECT p.product_id, p.sort_order, "1" AS match_filters, pp.sort_order FROM `oc_product` AS p INNER JOIN `oc_product_to_store` AS p2s ON (p2s.product_id = p.product_id) INNER JOIN `oc_bf_filter` AS f ON (p.product_id = f.product_id) INNER JOIN `oc_product_to_category` AS p2c ON (p.product_id = p2c.product_id) INNER JOIN `oc_category_path` AS cp ON (cp.category_id = p2c.category_id) INNER JOIN `oc_product_description` AS pd ON (pd.product_id = p.product_id) INNER JOIN `oc_product` AS pp ON (pp.product_id = p.product_id) WHERE p2s.store_id = '0' AND cp.path_id = '115' AND f.out_of_stock = 0 AND pd.language_id = '1' GROUP BY p.product_id HAVING match_filters = 1 ORDER BY pp.sort_order ASC, pd.name ASC LIMIT 0, 15
    2017-04-25 18:42:42 - PHP Notice:  Undefined index: status in /home/drvt/public_html/mystore/system/storage/modification/catalog/controller/common/column_left.php on line 95
    2017-04-25 18:42:42 - PHP Notice:  Undefined index: status in /home/drvt/public_html/mystore/system/storage/modification/catalog/controller/common/content_top.php on line 95
    
    Вот только мне не понятно что он потерял все таблицы к которым он ссылается на месте....
     
  8. TryCatch

    TryCatch

    Регистр.:
    19 авг 2016
    Сообщения:
    185
    Симпатии:
    76
    Эти таблицы никакого отношения к MFP не имеют, это таблицы Brainy Filter.
    Код метода getProducts() под спойлер выложите.
     
    Последнее редактирование: 25 апр 2017
  9. nloshka

    nloshka

    Регистр.:
    25 май 2012
    Сообщения:
    243
    Симпатии:
    210
    public function getProducts($data = array()) {
    $sql = "SELECT p.product_id, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special";

    if (!empty($data['filter_category_id'])) {
    if (!empty($data['filter_sub_category'])) {
    $sql .= " FROM " . DB_PREFIX . "category_path cp LEFT JOIN " . DB_PREFIX . "product_to_category p2c ON (cp.category_id = p2c.category_id)";
    } else {
    $sql .= " FROM " . DB_PREFIX . "product_to_category p2c";
    }

    if (!empty($data['filter_filter'])) {
    $sql .= " LEFT JOIN " . DB_PREFIX . "product_filter pf ON (p2c.product_id = pf.product_id) LEFT JOIN " . DB_PREFIX . "product p ON (pf.product_id = p.product_id)";
    } else {
    $sql .= " LEFT JOIN " . DB_PREFIX . "product p ON (p2c.product_id = p.product_id)";
    }
    } else {
    $sql .= " FROM " . DB_PREFIX . "product p";
    }

    $sql .= " LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'";

    if (!empty($data['filter_category_id'])) {
    if (!empty($data['filter_sub_category'])) {
    $sql .= " AND cp.path_id = '" . (int)$data['filter_category_id'] . "'";
    } else {
    $sql .= " AND p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
    }

    if (!empty($data['filter_filter'])) {
    $implode = array();

    $filters = explode(',', $data['filter_filter']);

    foreach ($filters as $filter_id) {
    $implode[] = (int)$filter_id;
    }

    $sql .= " AND pf.filter_id IN (" . implode(',', $implode) . ")";
    }
    }

    if (!empty($data['filter_name']) || !empty($data['filter_tag'])) {
    $sql .= " AND (";

    if (!empty($data['filter_name'])) {
    $implode = array();

    $words = explode(' ', trim(preg_replace('/\s+/', ' ', $data['filter_name'])));

    foreach ($words as $word) {
    $implode[] = "pd.name LIKE '%" . $this->db->escape($word) . "%'";
    }

    if ($implode) {
    $sql .= " " . implode(" AND ", $implode) . "";
    }

    if (!empty($data['filter_description'])) {
    $sql .= " OR pd.description LIKE '%" . $this->db->escape($data['filter_name']) . "%'";
    }
    }

    if (!empty($data['filter_name']) && !empty($data['filter_tag'])) {
    $sql .= " OR ";
    }

    if (!empty($data['filter_tag'])) {
    $implode = array();

    $words = explode(' ', trim(preg_replace('/\s+/', ' ', $data['filter_tag'])));

    foreach ($words as $word) {
    $implode[] = "pd.tag LIKE '%" . $this->db->escape($word) . "%'";
    }

    if ($implode) {
    $sql .= " " . implode(" AND ", $implode) . "";
    }
    }

    if (!empty($data['filter_name'])) {
    $sql .= " OR LCASE(p.model) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
    $sql .= " OR LCASE(p.sku) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
    $sql .= " OR LCASE(p.upc) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
    $sql .= " OR LCASE(p.ean) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
    $sql .= " OR LCASE(p.jan) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
    $sql .= " OR LCASE(p.isbn) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
    $sql .= " OR LCASE(p.mpn) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
    }

    $sql .= ")";
    }

    if (!empty($data['filter_manufacturer_id'])) {
    $sql .= " AND p.manufacturer_id = '" . (int)$data['filter_manufacturer_id'] . "'";
    }

    $sql .= " GROUP BY p.product_id";

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

    if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
    if ($data['sort'] == 'pd.name' || $data['sort'] == 'p.model') {
    $sql .= " ORDER BY LCASE(" . $data['sort'] . ")";
    } elseif ($data['sort'] == 'p.price') {
    $sql .= " ORDER BY (CASE WHEN special IS NOT NULL THEN special WHEN discount IS NOT NULL THEN discount ELSE p.price END)";
    } else {
    $sql .= " ORDER BY " . $data['sort'];
    }
    } else {
    $sql .= " ORDER BY p.sort_order";
    }

    if (isset($data['order']) && ($data['order'] == 'DESC')) {
    $sql .= " DESC, LCASE(pd.name) DESC";
    } else {
    $sql .= " ASC, LCASE(pd.name) ASC";
    }

    if (isset($data['start']) || isset($data['limit'])) {
    if ($data['start'] < 0) {
    $data['start'] = 0;
    }

    if ($data['limit'] < 1) {
    $data['limit'] = 20;
    }

    $sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
    }

    $product_data = array();


    if( in_array( __FUNCTION__, array( 'getProducts', 'getTotalProducts', 'getProductSpecials', 'getTotalProductSpecials' ) ) ) {
    if( ! empty( $this->request->get['mfp'] ) || ( NULL != ( $mfSettings = $this->config->get('mega_filter_settings') ) && ! empty( $mfSettings['in_stock_default_selected'] ) ) ) {
    if( empty( $data['mfp_disabled'] ) ) {
    $this->load->model( 'module/mega_filter' );

    if( class_exists( 'MegaFilterCore' ) ) {
    $sql = MegaFilterCore::newInstance( $this, $sql, $data )->getSQL( __FUNCTION__ );
    }
    }
    }
    }


    if( in_array( __FUNCTION__, array( 'getProducts', 'getTotalProducts', 'getProductSpecials', 'getTotalProductSpecials' ) ) ) {
    if( ! empty( $this->request->get['mfp'] ) || ( NULL != ( $mfSettings = $this->config->get('mega_filter_settings') ) && ! empty( $mfSettings['in_stock_default_selected'] ) ) ) {
    if( empty( $data['mfp_disabled'] ) ) {
    $this->load->model( 'module/mega_filter' );

    if( class_exists( 'MegaFilterCore' ) ) {
    $sql = MegaFilterCore::newInstance( $this, $sql, $data )->getSQL( __FUNCTION__ );
    }
    }
    }
    }

    $query = $this->db->query($sql);

    foreach ($query->rows as $result) {
    $product_data[$result['product_id']] = $this->getProduct($result['product_id']);
    }

    return $product_data;
    }
    Странно вроде все другие фильтры были удалены я даже файлы вычищал в ручную из директорий.
     
  10. rudoy88

    rudoy88 Писатель

    Регистр.:
    5 окт 2012
    Сообщения:
    8
    Симпатии:
    2
    Ползунок не двигается, как решить?
     
    Rudoy1488 нравится это.