Jump to content
Svetka0403

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

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 ---------*/
        );
    }

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

Share this post


Link to post
Share on other sites

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

 

 

Share this post


Link to post
Share on other sites

Не нашел в своем архиве дистрибутива 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

Share this post


Link to post
Share on other sites
11 часов назад, 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') . "'");

 

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

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

 

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


 

Share this post


Link to post
Share on other sites

 

6 минут назад, Svetka0403 сказал:

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

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

 

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

 

 

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

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.