Перейти до вмісту
Пошук в
  • Детальніше...
Шукати результати, які ...
Шукати результати в ...

Интеграция с RetailCRM


Svetka0403

Recommended Posts

Opencart версия 1.5.4.1 установлен официальный модуль от RetailCRM, но почему-то при выгрузке каталога товаров не выгружаются названия категорий.

В журнале ошибок пишет:

PHP Notice:  Undefined index: name in /home/morecvet/morecvetof.ru/www/admin/model/retailcrm/icml.php on line 74

private function addCategories()
    {
        $categories = $this->model_catalog_category->getCategories(array());
        foreach($categories as $category) {
            $category = $this->model_catalog_category->getCategory($category['category_id']);

            $e = $this->eCategories->appendChild(
                $this->dd->createElement(
                    'category', $category['name'] /*-------строка 74--------*/
                )
            );

            $e->setAttribute('id', $category['category_id']);

            if ($category['parent_id'] > 0) {
                $e->setAttribute('parentId', $category['parent_id']);
            }
        }

    }

Также не  проставляется значение опций

PHP Notice:  Undefined index: name in /home/morecvet/morecvetof.ru/www/admin/model/retailcrm/icml.php on line 350

private function getOptionData($optionId, $optionValueId) {
        if(!empty($this->options[$optionId])) {
            $option = $this->options[$optionId];
        } else {
            $option = $this->model_catalog_option->getOption($optionId);
            $this->options[$optionId] = $option;
        }

        if(!empty($this->optionValues[$optionValueId])) {
            $optionValue = $this->optionValues[$optionValueId];
        } else {
            $optionValue = $this->model_catalog_option->getOptionValues($optionValueId);
            $this->optionValues[$optionValueId] = $optionValue;
        }

        return array(
            'optionName' => $option['name'],
            'optionValue' => $optionValue['name'] /*------------ строка 350 ---------*/
        );
    }

Подскажите пожалуйста как поправить

Надіслати
Поділитися на інших сайтах


у меня нет под рукой вашей версии движка, проверить не смогу, но первое что бы я делал - прошел по запрашиваемым в коде функциям и проверил, возвращают ли они то, что от них ожидается.

 

 

Надіслати
Поділитися на інших сайтах

Не нашел в своем архиве дистрибутива 1.5.4, нашел предыдущую версию, глянул в модель, там действительно, выцепляет только данные с таблицы oc_category:

	public function getCategory($category_id) {
		$query = $this->db->query("SELECT DISTINCT *, (SELECT keyword FROM " . DB_PREFIX . "url_alias WHERE query = 'category_id=" . (int)$category_id . "') AS keyword FROM " . DB_PREFIX . "category WHERE category_id = '" . (int)$category_id . "'");
		
		return $query->row;
	} 

решением же для вашего вопроса, могу предложить добавить метод выборки данных раздела (файл: admin\model\catalog\category.php) перед функцией, что описана ранее:

	public function getFullCategory($category_id) {
		$query = $this->db->query("SELECT DISTINCT *, (SELECT GROUP_CONCAT(cd1.name ORDER BY level SEPARATOR ' > ') FROM " . DB_PREFIX . "category_path cp LEFT JOIN " . DB_PREFIX . "category_description cd1 ON (cp.path_id = cd1.category_id AND cp.category_id != cp.path_id) WHERE cp.category_id = c.category_id AND cd1.language_id = '" . (int)$this->config->get('config_language_id') . "' GROUP BY cp.category_id) AS path, (SELECT keyword FROM " . DB_PREFIX . "url_alias WHERE query = 'category_id=" . (int)$category_id . "') AS keyword FROM " . DB_PREFIX . "category c LEFT JOIN " . DB_PREFIX . "category_description cd2 ON (c.category_id = cd2.category_id) WHERE c.category_id = '" . (int)$category_id . "' AND cd2.language_id = '" . (int)$this->config->get('config_language_id') . "'");
		
		return $query->row;
	}

ну и в самом файле, там где ошибка в 74 строке, заменить: 

$category = $this->model_catalog_category->getCategory($category['category_id']);

на:

$category = $this->model_catalog_category->getFullCategory($category['category_id']);

~~~

по опциям же, надо смотреть функцию, в том же файле, где ошибки, под названием optionValues, а действовать - по аналогии, в общем - направление дал, вместо вас делать не буду... за лайк решения, заранее спасибо.

  • +1 1
Надіслати
Поділитися на інших сайтах

  В 13.01.2019 в 06:27, auditor сказав:

$query = $this->db->query("SELECT DISTINCT *, (SELECT GROUP_CONCAT(cd1.name ORDER BY level SEPARATOR ' > ') FROM " . DB_PREFIX . "category_path cp LEFT JOIN " . DB_PREFIX . "category_description cd1 ON (cp.path_id = cd1.category_id AND cp.category_id != cp.path_id) WHERE cp.category_id = c.category_id AND cd1.language_id = '" . (int)$this->config->get('config_language_id') . "' GROUP BY cp.category_id) AS path, (SELECT keyword FROM " . DB_PREFIX . "url_alias WHERE query = 'category_id=" . (int)$category_id . "') AS keyword FROM " . DB_PREFIX . "category c LEFT JOIN " . DB_PREFIX . "category_description cd2 ON (c.category_id = cd2.category_id) WHERE c.category_id = '" . (int)$category_id . "' AND cd2.language_id = '" . (int)$this->config->get('config_language_id') . "'");

Expand  

 

Пробовала сделать как Вы сказали, но выдает ошибку:

Parse error: syntax error, unexpected '' (T_STRING) in /home/morecvet/morecvetof.ru/www/admin/model/catalog/category.php on line 95

 

Готова заплатить за помощь


 

Надіслати
Поділитися на інших сайтах


 

  В 13.01.2019 в 21:44, Svetka0403 сказав:

Пробовала сделать как Вы сказали, но выдает ошибку:

Parse error: syntax error, unexpected '' (T_STRING) in /home/morecvet/morecvetof.ru/www/admin/model/catalog/category.php on line 95

 

Готова заплатить за помощь

 

Expand  

 

Могу помочь, скиньте доступы в личку.

Надіслати
Поділитися на інших сайтах

  • 4 months later...
  • 1 month later...
  В 12.06.2019 в 21:06, rozario888 сказав:

У кого есть рабочая интеграция? Которую они предлагают надо допиливать или будет из коробки работать? На сайте есть симпла и шаблон течстор

Expand  

 

Нужно будет дорабатывать

Надіслати
Поділитися на інших сайтах


  В 19.07.2019 в 20:29, rozario888 сказав:

Что именно? У меня все так заработало

Expand  

 

Топикстертеру я допиливал модуль, были косяки с характеристиками и еще не помню уже с чем. Но там была 1.5, может для 2-3 уже нет таких проблем.

Надіслати
Поділитися на інших сайтах

  В 20.07.2019 в 18:08, Vetroff сказав:

может для 2-3 уже нет таких проблем.

Expand  

Проблема есть с передачей данных по доставке, когда задано условие по цене (до платно, от бесплатно), а в соответствии только один из вариантов. Симпла аналогично видит только один в настройках

Надіслати
Поділитися на інших сайтах


@rozario888 а в чем проблема с условием по цене? у меня несколько таких доставок (с обнулением доставки при достижении некоторого порога по сумме)- созданы через filterit, все передается корректно. 

Проблема с подстановкой данных по доставке в заказ retailCRM- какой ПВЗ, какой тариф- надо руками все выбирать- но работать можно и так, плюс незавершенные заказы, которые создаются в retailCRM- их приходится удалять систематически. 

Надіслати
Поділитися на інших сайтах


  В 21.07.2019 в 02:30, jimmie сказав:

а в чем проблема с условием по цене?

Expand  

По умолчанию задан один тип доставки, а по факту приходит другой. Может это из-за того, что в настройках соответствия выбирается общий, например, доставка по Москве. А она делится на два.

Я в итоге отказался от ретейла, у них нет решений по складу, чтобы можно было в системе хотя бы информативно видеть раскладку как в 1С поставщика (квоты, резервы).

Надіслати
Поділитися на інших сайтах


А, ну наверное надо было и в retailCRM два вида доставок делать и сцеплять их к доставками в магазине, если они идут у вас разными пунктами. 

В пользу чего отказались? 

В плане работы с курьерками это вроде как лучшая среда. 

Надіслати
Поділитися на інших сайтах


  • 5 weeks later...
  В 21.07.2019 в 02:30, jimmie сказав:

@rozario888 а в чем проблема с условием по цене? у меня несколько таких доставок (с обнулением доставки при достижении некоторого порога по сумме)- созданы через filterit, все передается корректно. 

Проблема с подстановкой данных по доставке в заказ retailCRM- какой ПВЗ, какой тариф- надо руками все выбирать- но работать можно и так, плюс незавершенные заказы, которые создаются в retailCRM- их приходится удалять систематически. 

Expand  

 

создаются в retailCRM- их приходится удалять систематически. - такая же история!!!  Может кто решить вопрос?

Надіслати
Поділитися на інших сайтах


  • 2 months later...

Добрый день!

Может кто сталкивался, ставлю на опенкарт 1.5.6 , при формировании каталога получаю ошибку:

Fatal error: Call to undefined method ModelCatalogOption::getOptionValue() in /home/ecoelekt/ecoelectro.com.ua/www/admin/model/retailcrm/icml.php on line 344
 

Версия старое, все это уже особо не поддерживается, но сейчас нужно именно на эту версию.

Если у кого-то есть готовые решения, готов оплатить настройку.

Надіслати
Поділитися на інших сайтах


  В 26.10.2019 в 10:00, khvoroffski сказав:

Если у кого-то есть готовые решения, готов оплатить настройку.

Expand  

 

Спросите у ТС ) если она согласится файлы своего движка предоставить.

По памяти, там допиливался и этот файл и модель или контроллер опций, все довольно печально было.

Надіслати
Поділитися на інших сайтах

  В 26.10.2019 в 19:25, Vetroff сказав:

 

Спросите у ТС ) если она согласится файлы своего движка предоставить.

По памяти, там допиливался и этот файл и модель или контроллер опций, все довольно печально было.

Expand  

Написал, надеюсь ответит.

По ощущениям там в каждом файле будет проблема, потому что и история не работает и тп...

Надіслати
Поділитися на інших сайтах


Створіть аккаунт або увійдіть для коментування

Ви повинні бути користувачем, щоб залишити коментар

Створити обліковий запис

Зареєструйтеся для отримання облікового запису. Це просто!

Зареєструвати аккаунт

Вхід

Уже зареєстровані? Увійдіть тут.

Вхід зараз
  • Зараз на сторінці   0 користувачів

    • Ні користувачів, які переглядиють цю сторінку
×
×
  • Створити...

Important Information

На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність.