Последние темы


CatalogFill игнорирует изменение категорий.

  • Добрый день, при загрузке категорий использую конфигуратор с поддержкой категорий, обновление у меня происходит по tv полю sku, если товара не существует то все хорошо, он создает новый товар и присваивает его в ту категорию которую я поставил в прайс листе, но вот если товар уже существует,, то категорию он не меняет!!! Странно что цену меняет, производителя меняет, а категорию не хочет никак.. Кто сталкивался, если нужно могу прислать конфигуратор.. Но думаю дело не в нем.

  • Да, это не предусмотрено. Но могу подсказать где в коде поправить. Покажите конфигурацию.

  • @andchir

    <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
       array('SKU',array(21,'tv')),
       array('Пропуск',array('null','null')),
       array('Наименование',array('pagetitle','content')),
       array('Цена',array(2,'tv')),
       array('Валюта',array(23,'tv')),
       array('Пропуск',array('null','null')),
       array('Публикация',array('published','content')),
       array('Производитель',array(17,'tv')),
       array('Категория',array(27,'category')),//3 - ID шаблона категории
       array('Подкатегория',array(27,'category')),//3 - ID шаблона подкатегории
       array('Подкатегория2',array(27,'category'))//3 - ID шаблона категории
    
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
       'content' => array(
           'published' => 1,
           'template' => 35
           //'createdon' => strtotime("now")
       ),
       'tv' => array(
           //7 => 0
       )
    
    );
    
    //первая строка - названия полей
    $cf_config['include_captions'] = true;
    
    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 300;
    
    //разбивать по категориям
    $cf_config['include_categories'] = true;
    
    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = true;
    
    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = false;
    
    //проверять соответствие товара при обновлении по значению TV. Указать ID TV. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_tvid_val'] = '21';
    
    //Добавлять товары, которые не найдены при обновлении по TV (imp_chk_tvid_val) или полю (imp_chk_field)
    $cf_config['imp_if_not_exist'] = true;
    
    //удалять HTML-теги при экспорте
    $cf_config['exp_strip_tags'] = false;
    
    //автоматически генерировать псевдоним (alias) при импорте
    //false - выключено; true - генерировать с переводом в транслит; 'notranslit' - генерировать без перевода в транслит.
    $cf_config['imp_autoalias'] = true;
    
    //Изменить значения поля для всех вложенных товаров до начала импорта.
    //Например можно отменить публикацию для всех товаров и публиковать только те, которые есть в новом прайс-листе.
    //первый массив - какие поля и на какие значения менять, второй массив - условия которые нужно проверять (можно сделать пустым)
    $cf_config['imp_before_change'] = false;//'[{"tv.inventory":0},{}]';//'[{"published":0},{"tv.pricename":"Поставщик1"}]';//false - для отмены
    
    //удалить файл после экспорта (скачивания)
    $cf_config['exp_delete_file'] = false;
    
    //кодировка CSV-файла при экспорте
    $cf_config['exp_csv_charset'] = 'UTF-8';//'windows-1251'
    
    //Импортировать (обновлять) пустые значения
    $cf_config['imp_empty'] = true;
    
    //Имя файла процессора, который использовать для импорта. Если пусто, используется стандартный процессор "import".
    $cf_config['imp_custom_processor'] = '';
    
    //путь (xpath) в XML структуре до товаров
    $cf_config['imp_xml_itemsparent_path'] = '';//'/catalog/shop/offers'
    
    //Структура XML файла для импорта
    $cf_config['imp_xml_structure'] = '';
    
    //тестирование конфигурации (без записи в БД)
    $cf_config['imp_testmode'] = false;
    
    
    //функция для фильтрации значений при ИМПОРТЕ
    function filter_import($value_arr){
       $output_arr = $value_arr;
       /*
       if(isset($output_arr['content']['pagetitle']))
           $output_arr['content']['pagetitle'] = mb_strtoupper($output_arr['content']['pagetitle'], 'UTF-8');
       */
       
       
       return $output_arr;
    }
    
    
    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr,$doc_id=0){
    
       $output_arr = $value_arr;
    
    
       return $output_arr;
    }
    
    ?>
    
  • Какая версия CatalogFill у вас?

  • Если версия 2.4.9-pl1 то в файле catalogfill.class.php найти строку 947 и раскомментировать её (убрать // в начале строки)

    unset( $insertArr['content'][$this->config['parent_field']] );
    
  • Версия 2.4.7pl

    	//Обновление товара
            if($is_update && $upd_id){
                
                $sql = "UPDATE `".$this->config['table_name']."` SET\n";
                
                unset( $insertArr['content'][$this->config['parent_field']] );
                
                foreach(array_keys($insertArr['content']) as $fname){
                    $sql .= " `{$fname}` = ?,\n";
                }
                
                $sql = substr($sql,0,-2);
                
                $sql .= "\nWHERE `id` = '{$upd_id}' LIMIT 1";
                
                $stmt = $this->modx->prepare($sql);
                if($stmt && $stmt->execute(array_values($insertArr['content']))){
                    
                    $stmt->closeCursor();
                    $this->updateTVs($insertArr['tv'],$upd_id);
                    $output = true;
                    
                }else{
                    
                    $this->modx->log(modX::LOG_LEVEL_ERROR, "catalogFill: ".implode(', ',$stmt->errorInfo()));
                    $stmt->closeCursor();
                    $output = false;
                    
                }
                
                $output = true;
    
  • У меня эти строки уже раскомментированы, но как я понимаю, это не помогает,при одновлении категории не меняются..

  • Эта запись удалена!
  • Надо использовать последнюю версию.

  • Приобрел версию 2.4.9pl
    Раскомментировал в файле catalogfill.class.php
    строку

    unset( $insertArr['content'][$this->config['parent_field']] );
    

    Взял для примера нативный конфигуратор width_categories,php
    Перенастроил на свой шаблон и свои поля
    Сделал экспорт => удалил все товары кроме одного => в нем заменил цену и подкатегорию и импортировал этим же конфигуратором обратно через "обновить"
    Результат: цена изменилась, конечная категория не поменялась.

  • Если конфигурация изменилась, то надо её показать. Так же очень желательно показать файл, который импортируете.

  • Конфигурация

    <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        array('Категория',array(27,'category')),//3 - ID шаблона категории
        array('Подкатегория',array(27,'category')),//3 - ID шаблона подкатегории
    	 array('Подкатегория2',array(27,'category')),//3 - ID шаблона подкатегории
        array('Наименование',array('pagetitle','content')),
        array('Цена',array(2,'tv')),
        array('Валюта',array(23,'tv')),
        array('Производитель',array(17,'tv')),
    	 array('SKU',array(21,'tv'))
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'published' => 1,
            'template' => 35
            //'createdon' => strtotime("now")
        ),
        'tv' => array(
            //7 => 0
        )
    );
    
    //первая строка - названия полей
    $cf_config['include_captions'] = true;
    
    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 300;
    
    //разбивать по категориям
    $cf_config['include_categories'] = true;
    
    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = false;
    
    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = false;
    
    //проверять соответствие товара при обновлении по значению TV. Указать ID TV. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_tvid_val'] = '21';
    
    //Добавлять товары, которые не найдены при обновлении по TV (imp_chk_tvid_val) или полю (imp_chk_field)
    $cf_config['imp_if_not_exist'] = true;
    
    //удалять HTML-теги при экспорте
    $cf_config['exp_strip_tags'] = false;
    
    //автоматически генерировать псевдоним (alias) при импорте
    //false - выключено; true - генерировать с переводом в транслит; 'notranslit' - генерировать без перевода в транслит.
    $cf_config['imp_autoalias'] = true;
    
    //Изменить значения поля для всех вложенных товаров до начала импорта.
    //Например можно отменить публикацию для всех товаров и публиковать только те, которые есть в новом прайс-листе.
    //первый массив - какие поля и на какие значения менять, второй массив - условия которые нужно проверять (можно сделать пустым)
    $cf_config['imp_before_change'] = false;//'[{"tv.inventory":0},{}]';//'[{"published":0},{"tv.pricename":"Поставщик1"}]';//false - для отмены
    
    //удалить файл после экспорта (скачивания)
    $cf_config['exp_delete_file'] = false;
    
    //кодировка CSV-файла при экспорте
    $cf_config['exp_csv_charset'] = 'UTF-8';//'windows-1251'
    
    //Импортировать (обновлять) пустые значения
    $cf_config['imp_empty'] = true;
    
    //Имя файла процессора, который использовать для импорта. Если пусто, используется стандартный процессор "import".
    $cf_config['imp_custom_processor'] = '';
    
    //путь (xpath) в XML структуре до товаров
    $cf_config['imp_xml_itemsparent_path'] = '';//'/catalog/shop/offers'
    
    //Структура XML файла для импорта
    $cf_config['imp_xml_structure'] = '';
    
    //тестирование конфигурации (без записи в БД)
    $cf_config['imp_testmode'] = false;
    
    //функция для фильтрации значений при ИМПОРТЕ
    function filter_import($value_arr){
        $output_arr = $value_arr;
        /*
        if(isset($output_arr['content']['pagetitle']))
            $output_arr['content']['pagetitle'] = mb_strtoupper($output_arr['content']['pagetitle'], 'UTF-8');
        */
        return $output_arr;
    }
    
    
    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr,$doc_id=0){
        $output_arr = $value_arr;
        //var_dump($value_arr,$output_arr);
        //exit;
        /*
        if(isset($output_arr['price']))
            $output_arr[1] = floatval($output_arr[1]) - 200;
        */
        return $output_arr;
    }
    
    ?>
    

    Пример файла в котором обновил подкатегорию у одного товара.
    Было "АНАЛИЗАТОРЫ СПЕКТРА", должно стать "АНАЛИЗАТОРЫ ЦЕПЕЙ"
    https://yadi.sk/i/YCMZ8Ffi3Vt9Tb
    При прогрузке если меняю цену или производителя или валюту все, меняется, но родительская категория в админке на странице товара как была "АНАЛИЗАТОРЫ СПЕКТРА" так и осталась.

  • А если вернуть как было? Вроде в последней версии уже было сделано то что нужно. Не нужно раскомментировать строчку.

  • Участник @andchir написал в CatalogFill игнорирует изменение категорий.:

    А если вернуть как было? Вроде в последней версии уже было сделано то что нужно. Не нужно раскомментировать строчку.

    Да, спасибо!!! ВСЕ ЗАРАБОТАЛО!!!

 

Последние комментарии

  • Z

    Спасибо, действительно проще создать отдельно.

    Читать далее
  • Но проблема в том, что эта старая цена "дублируется" в плесхолдер "Дополнительных услуг" - [[+addit_data]].

    Можно не использовать [[+addit_data]], а выводить параметры по-отдельности.

    Цитата из документации:

    [[+shk_любой доп.параметр]] - любой доп. параметр, выбранный при добавлении товара в корзину (из [[+addit_data]]), например [[+shk_param1]].
    Если параметры сделаны в виде чекбоксов, то чтобы вывести отдельно каждый из них, нужно добавлять индекс (номер от нуля) для параметров следующих за первым.
    Пример: [[+shk_param1]], [[+shk_param1_1]], [[+shk_param1_2]] ...
    [[+shk_любой доп.параметр_price]] - цена доп.параметра. Пример: [[+shk_param1_price]].

    Читать далее
  • Z

    Доброго времени суток. Не могу разобраться, как передать данные migx-поля в корзину в плейсхолдер без "дублирования" в [[+addit_data]]
    Суть в чем: У меня есть 2 цены у товара (со скидкой и без скидки) Форма для отправки в корзину:

    <form action="[[~[[*resource_id]]? &scheme=`abs`]][[*alias]].html" method="post"> <input type="hidden" name="shk-id" value="[[*id]]" /> <input type="hidden" name="shk-name" value="[[*pagetitle]]" /> <input type="hidden" name="price_old__[[*id]]__add" value="[[*price_old]]" /> <input type="hidden" name="shk-count" value="1" /> <div class="product-price"> Цена: <span class="shk-price">[[!*price:shk_curr_rate:num_format]]</span> Старая цена - <span class="shk-price-old">[[+price_old]]</span> [[!+shk_currency]] </div> <div class="padding-lr-30"> <h5>Дополнительные услуги</h5> [[*param1]] </div> <div class="product-price"> <button class="btn btn-lg btn-primary" type="submit" class="shk-but">В корзину</button> </div> </form>

    Данные со "старой ценой" в корзину попадают нормально и выводится в нужном месте в плейсхолдере:
    [[+shk_price_old]]
    Но проблема в том, что эта старая цена "дублируется" в плесхолдер "Дополнительных услуг" - [[+addit_data]]. Как сделать чтобы старая цена не выводилась в [[+addit_data]]? Или может я как то не правильно передаю MIGX-параметр в корзину ? Заранее спасибо.

    Читать далее
  • Фотографии, как я понял, это второй вопрос. Я по нему пока ничего не отвечал и не просил информации. Это не отменяет того, что в вашем конфиге есть ошибка, о которой я писал выше. Не нужно задавать разные вопросы в одной теме, чтобы не было путаницы.
    http://forum.modx-shopkeeper.ru/topic/15/рекомендации-по-оформлению-темы-с-вопросом

    Читать далее