• S
    Surf

    @Andchir Я может не понятно пишу? Если товары не добавляются, то они обновляются. Какой вариант конфигурации позволяет добавить товары без обновления существующих и создания дублей?

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Мне надо добавить товары из файла, но только тех которых нет. С false не добавляются с true тоже. Во всех случаях или добавляются товары с такими же артикулами или же обновляются уже имеющиеся, то есть товар не добавляется, но изменяется заголовок, цена и.т.п.
    У меня изначально стоял параметр false, я пробую и так и сяк, уже раз 100 приходилось восстанавливать сайт из резервной БД...

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Где там, в каких скобочках?

    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = 'articul';
    
    //Добавлять товары, которые не найдены при обновлении по TV (imp_chk_tvid_val) или полю (imp_chk_field)
    $cf_config['imp_if_not_exist'] = true;
    

    Если товар существует, надо что бы он не обновлялся.

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Если добавляю, то добавляются дубли страниц. Если обновляю, то изменяются значения полей, так как в импортируемом файле и на сайте они разные. Надо что бы catalogfill вообще не трогал существующие товары, так как там частично изменена информация.

    написал в Поддержка Читать далее
  • S
    Surf

    Необходимо дополнить catalogfill возможностью загрузки и добавления изображений в галерею. Количество изображений у товаров разное
    modx shk3 migx

    Вот код, который необходимо доработать.

    function filter_import($value_arr) {
        $imagesDirUrl = MODX_BASE_URL . 'assets/images/';
        $imagesDirPath = MODX_BASE_PATH . 'assets/images/';
    
        $output_arr = $value_arr;
        
        if(isset($output_arr['content']['image'])) {
            $imageFilePath = $imagesDirPath . basename($output_arr['content']['image']);
            if (!file_exists($imageFilePath)) {
                file_put_contents($imageFilePath, file_get_contents(trim($output_arr['content']['image'])));
            }
            $output_arr['content']['image'] = $imagesDirUrl . basename(trim($output_arr['content']['image']));
        }
        
        return $output_arr;
    }
    

    По идее стандартная процедура. Должен быть готовый вариант?

    написал в Поддержка Читать далее
  • S
    Surf

    Необходимо сделать так, что бы при импорте товаров не добавлялись и не обновлялись те товары, которые уже существуют. Проверка по артикулу
    modx 2.7 shk3 migx

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Разобрался.
    Вот в этой строчке убрал не - !

    if(!empty($output_arr['content']['available']))
    

    Вот так всё работает. Ну конечно наличие теперь не - 0, а - 1

     if(empty($output_arr['content']['available']))
    

    Теперь надо сделать что бы каждая картинка грузилась в отдельную папку с названием артикула и грузились картинки в галерею. Картинок у товаров разное количество.

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Теперь код даже в поле 'Картинка' не добавляет путь на хостинг, как впрочем и не закачивает картинку на хостинг.

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir

    Ответы с обновлённым кодом.

    1

    {"success":true,"message":"","total":0,"data":[],"object":{"pos":0,"lines_count":1}}
    

    2 - первый вариант кода выдавал здесь - NULL

    string(76) "hosting/site.ru/assets/images/shokolad.png"
    string(84) "http://site.ru/files/images/shokolad.png"
    

    3

    {"success":true,"total":3,"results":{"resources":51,"resources_pub":46,"tvs":65}}
    

    В прошлый раз неправильный конфиг запустил. Сейчас вот такой:

    <?php
    
    //Название класса таблицы товаров в БД
    $cf_config['className'] = 'shopContent';
    //Название пакета таблицы товаров в БД
    $cf_config['packageName'] = 'shop';
    //Название поля ID родителя
    $cf_config['parent_field'] = 'resource_id';
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        array('Артикул',array('articul','content')),
        array('Наименование',array('pagetitle','content')),
        array('Цена',array('price','content')),
    	array('Страна',array('country','content')),
    	array('Состав',array('consist','content')),
    	array('Размер',array('size','content')),
    	array('В наличии',array('available','content')),
    	array('Картинка',array('image','content'))
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'deleted' => 0,
            'published' => 0,
            'template' => 3
            //'createdon' => strtotime("now")
            //'publishedon' => strtotime("now")
            //'pub_date' => strtotime("now")
            //'editedby' => 1
            //'editedon' => strtotime("now")
        ),
        'tv' => array(
            //7 => 0
        )
    );
    
    //первая строка - названия полей
    $cf_config['include_captions'] = true;
    
    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 300;
    
    //разбивать по категориям
    $cf_config['include_categories'] = false;
    
    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = true;
    
    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = 'articul';
    
    //проверять соответствие товара при обновлении по значению TV. Указать ID TV. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_tvid_val'] = false;
    
    //Добавлять товары, которые не найдены при обновлении по 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'] = '[{"published":0},{"tv.available":"0"}]'; //'[{"published":1},{"tv.available":0}]';//'[{"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) {
        $imagesDirUrl = MODX_BASE_URL . 'assets/images/';
        $imagesDirPath = MODX_BASE_PATH . 'assets/images/';
    
        $imageFilePath = $imagesDirPath . basename($value_arr['content']['image']);
    
        var_dump($imageFilePath, $value_arr['content']['image']); exit;
    }
    
    
    
    /*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;
    }*/
    
    
    ?>
    

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir
    1

    {"success":true,"message":"","total":0,"data":[],"object":{"pos":0,"lines_count":1}}
    

    2

    {"success":true,"message":"","total":0,"data":[],"object":{"pos":0,"lines_count":0}}
    

    3

    {"success":true,"total":3,"results":{"resources":51,"resources_pub":46,"tvs":65}}
    

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir А где надо посмотреть? В момент импорта или просто отдельным файлом записать этот код и открыть его через браузер? В момент импорта несколько файлов catalogfil запускаются.

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Какая информация нужна, может мне у админов хостинга спросить и не танцевать с бубнами?

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir

    function filter_import($value_arr) {
        var_dump($output_arr['content']['image']); exit;
    }
    

    Вот с этой функцией catalogfil не запускается. В консоли catalogfil нет. Я эту функцию просто в php файл засунул, но он тоже не отображается.

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir

    <?php
    
    //Название класса таблицы товаров в БД
    $cf_config['className'] = 'shopContent';
    //Название пакета таблицы товаров в БД
    $cf_config['packageName'] = 'shop';
    //Название поля ID родителя
    $cf_config['parent_field'] = 'resource_id';
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        array('Артикул',array('articul','content')),
        array('Наименование',array('pagetitle','content')),
        array('Цена',array('price','content')),
    	array('Страна',array('country','content')),
    	array('Состав',array('consist','content')),
    	array('Размер',array('size','content')),
    	array('В наличии',array('available','content')),
    	array('Картинка',array('image','content'))
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'deleted' => 0,
            'published' => 0,
            'template' => 3
            //'createdon' => strtotime("now")
            //'publishedon' => strtotime("now")
            //'pub_date' => strtotime("now")
            //'editedby' => 1
            //'editedon' => strtotime("now")
        ),
        'tv' => array(
            //7 => 0
        )
    );
    
    //первая строка - названия полей
    $cf_config['include_captions'] = true;
    
    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 300;
    
    //разбивать по категориям
    $cf_config['include_categories'] = false;
    
    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = true;
    
    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = 'articul';
    
    //проверять соответствие товара при обновлении по значению TV. Указать ID TV. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_tvid_val'] = false;
    
    //Добавлять товары, которые не найдены при обновлении по 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'] = '[{"published":0},{"tv.available":"0"}]'; //'[{"published":1},{"tv.available":0}]';//'[{"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) {
        $imagesDirUrl = MODX_BASE_URL . 'assets/images/';
        $imagesDirPath = MODX_BASE_PATH . 'assets/images/';
    
        $output_arr = $value_arr;
    
        if(!empty($output_arr['content']['available'])) {
             return null;
        }
        
        if(isset($output_arr['content']['image'])) {
            $imageFilePath = $imagesDirPath . basename($output_arr['content']['image']);
            if (!isset($imageFilePath)) {
                file_put_contents($imageFilePath, file_get_contents(trim($output_arr['content']['image'])));
            }
            $output_arr['content']['image'] = $imagesDirUrl . basename(trim($output_arr['content']['image']));
        }
        
        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;
    }*/
    
    
    ?>```

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Никакого, этот код ничего не делает

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Вот такой вот файл:
    0_1543686957924_36116996-ed5f-4734-b944-c00737d8b1dd-image.png
    Артикул Наименование Цена Страна Состав Размер В наличии Картинка
    artshoko Шоколад "Алёнка" 25 Россия Какао 50x80 0 http://site.ru/images/shokolad/alenka-molochnaya.png

    Картинка по адресу доступна. Импортируются все поля, в поле картинка правильно указывается адрес картинки на хостинге, но на сам хостинг изображение не загружается.

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir Да, проверил, права на запись в эту папку есть.

    написал в Поддержка Читать далее
  • S
    Surf

    @Andchir В поле добавляется адрес изображения, но на хостинг оно при этом не закачивается.

    написал в Поддержка Читать далее