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


CatalogFill и filter_export

  • Добрый день, нужно соединить 3 тв поля в поле pagetitle, пытаюсь делать через filter_export, но не хочет работать, глянул как делать для импорта

    tv 11 - Вес
    tv 6 - Цена
    подскажите в чем проблема, спасибо заранее, уже поразному вписывал значение и через $output_arr['tv']['6'] и просто название $output_arr['price'] вообще не хочет работать
    modx 2.7.1
    catalogfill 2.4.10-pl

    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr,$doc_id=0){
    	
        $output_arr = $value_arr;
        //var_dump($value_arr,$output_arr);
        //exit;
    	  if(isset($output_arr['pagetitle'])) {
    $output_arr['pagetitle'] = $output_arr['pagetitle'] . ' '. $output_arr[11]  . ' '. $output_arr[6];
    	 }
        return $output_arr;
    } 
    
  • При экспорте поля и значения ТВ параметров разделены, поэтому соединить можно только поля или ТВ отдельно. Поля с ТВ нельзя.

  • @Andchir спасибо за ответ, а никак их соединить нельзя будет? если например прямой sql запрос попробовать сделать?
    П.С., а где смотреть весь код который делаешь? например через print_r или var_dump?

  • Вы первый, кто хочет соединить при экспорте. Обычно соединяют и т.п. при импорте. Там есть возможность соединить поля и ТВ.

    П.С., а где смотреть весь код который делаешь? например через print_r или var_dump?

    Открывайте файл catalogfill.class.php в текстовом редакторе и ищите где вызывается функция filter_export().

  • @Andchir еще хотел спросить, как можно реализовать разделение столбцов при экспорте тип ввода ТВ param-edit, в экселе выводит видalt text нужно через разделитель || сделать 2 столбца и т.д., я понимаю что нужно через filter_export, можете подсказать, спасибо

  • нужно через разделитель || сделать 2 столбца и т.д.

    Создаете дополнительную колонку (можно несколько) после ТВ, значение которого нужно разделить. ID ТВ для такой колонки можно указать, тот которого не существует.

    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        ...
        array('Параметры товара', array(2, 'tv')),
        array('Параметры товара - вторая колонка', array(2000, 'tv'))// Дополнительная колонка в экселе
    );
    

    Далее в конфигурационном файле разделяете с помощью функции filter_export().

    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr, $doc_id=0){
        $output_arr = $value_arr;
        if(!empty($output_arr[2])) {
            $tmp = explode('||', $output_arr[2]);// Разделяем строку, получаем массив
            if (count($tmp) >= 2) {
                $output_arr[2] = $tmp[0];
                $output_arr[2000] = $tmp[1];
            }
        }
        return $output_arr;
    }
    
  • Участник @Andchir написал в CatalogFill и filter_export:

    нужно через разделитель || сделать 2 столбца и т.д.

    Создаете дополнительную колонку (можно несколько) после ТВ, значение которого нужно разделить. ID ТВ для такой колонки можно указать, тот которого не существует.

    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        ...
        array('Параметры товара', array(2, 'tv')),
        array('Параметры товара - вторая колонка', array(2000, 'tv'))// Дополнительная колонка в экселе
    );
    

    Далее в конфигурационном файле разделяете с помощью функции filter_export().

    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr, $doc_id=0){
        $output_arr = $value_arr;
        if(!empty($output_arr[2])) {
            $tmp = explode('||', $output_arr[2]);// Разделяем строку, получаем массив
            if (count($tmp) >= 2) {
                $output_arr[2] = $tmp[0];
                $output_arr[2000] = $tmp[1];
            }
        }
        return $output_arr;
    }
    

    работает отлично, спасибо

 

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

  • K

    Участник @Andchir написал в Название товара в теме письма:

    $_SESSION['shk_order']

    да, спасибо - все получилось

    Читать далее
  • Можете написать сниппет, который будет выводить название товара, и использовать его в параметре сниппета FormIt так же как сейчас используется плейсхолдер [[++site_name]].
    Товары находятся в сессии $_SESSION['shk_order'].

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

    Shopkeeper3

    Можно ли как-то в теме письма (которое приходит администратору) указать Fullname и Название купленного продукта?
    Т.е. вместо этого: В интернет-магазине "[[++site_name]]" сделан новый заказ
    Получить, например: Иванов Иван купил Чайник

    На сайте нет корзины (которая отображается пользователю) и пользователь может купить только один товар за один заказ.

    Моя фантазия пока не может придумать, как это сделать (может какой-то плагин написать?)..

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

    @Andchir все работает!
    Спасибо!

    Читать далее