Новости Joomla

Совет по Joomla: несколько значений по умолчанию в XML-формах для стандартных полей типа list

👩‍💻 Совет по Joomla: несколько значений по умолчанию в XML-формах для стандартных полей типа list.При работе над плагином возникла необходимость указать стандартный набор из нескольких элементов стандартного поля списка. И хотелось указать их в стандартном же атрибуте default для полей. Когда это нужно?Когда Ваши пользователи устанавливают плагин и НЕ заходят в настройки - в коде вы можете использовать значения по умолчанию с помощью класса Registry (писал об этом ранее) и всегда быть уверенным, что хоть какие-то жизненно необходимые параметры к вам придут всегда. 🧐 Но как сделать то же самое для интерфейса админки?Пользователя нужно направлять, предлагать очевидный работоспособный сценарий для начала, а дальше он уже сам разберется. Когда человек заходит в параметры свежеустановленного плагина в Form ещё нет данных и параметры по умолчанию выставляются из атрибутов default в xml-полях.
<field name="showdesc" type="radio"                       label="PLG_CFI_PARAM_SHOWDESC"                       class="btn-group btn-group-yesno"                       default="1">                    <option value="0">JNO</option>                    <option value="1">JYES</option>                </field>
Здесь по умолчанию будет включено "Да". И если пользователь не переключит параметр, то при сохранении мы ожидаемо получим "да" в params плагина.Для поля списков type=&quot;list&quot; можно указать значение по умолчанию и многие знают, что его можно указать только одно.
<field type="list"                       name="article_fields"                       label="article_fields"                       description="article_fields_desc"                       layout="joomla.form.field.list-fancy-select"                       multiple="true"                       default="id"                >                    <option value="id">id</option>                    <option value="title">title</option>                    <option value="alias">alias</option>                    <option value="introtext">introtext</option>                    <option value="fulltext">fulltext</option>                    <option value="state">state</option></field>
Но у нас поле с множественным выбором (атрибут multiple) и хотелось бы указать несколько значений по умолчанию...Оказывается, так можно сделать. Для этого в атрибуте default нужно указать json с нужными параметрами в виде {int}key : {string} value.Например, default='{"0":"id","1":"title"}'.
<field type="list"                       name="article_fields"                       label="article_fields"                       description="article_fields_desc"                       layout="joomla.form.field.list-fancy-select"                       multiple="true"                       default='{"0":"id","1":"title"}'                >                    <option value="id">id</option>                    <option value="title">title</option>                    <option value="alias">alias</option>                    <option value="introtext">introtext</option>                    <option value="fulltext">fulltext</option>                    <option value="state">state</option></field>
⚠️ Обратите внимание на кавычки! Поскольку json_decode не понимает одинарные кавычки собственно json нужно писать с двойными, а значение для атрибута default писать в одинарные.🙏 За подсказанное решение огромное спасибо участникам нашего сообщества - разработчикам Дмитрию Васюкову (@fictionlabs) и Игорю Бердичевскому (@septdir).@joomlafeed#joomla #разработка #webdev #development

0 Пользователей и 1 Гость просматривают эту тему.
  • 11 Ответов
  • 4556 Просмотров
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Тут без вмешательства в код ядра не обошлось, но у меня все характеристики должны быть с мультивыбором и других вариантов я не увидел, так-что хакаем ядро:

Админка

1. \administrator\components\com_jshopping\controllers\products.php
Меняем строку
Код: php
$obj->values = JHTML::_('select.genericlist', array_merge($f_option, $tmp), $name, '', 'id', 'name', $product->$name);

На
Код: php
$selected = explode(',', $product->$name);
                $obj->values = JHTML::_('select.genericlist', array_merge($f_option, $tmp), $name.'[]', 'class="inputbox" size="10" multiple="multiple"', 'id', 'name', $selected);

2. После строки
Код: php
$dispatcher->trigger( 'onBeforeDisplaySaveProduct', array(&$post) );

Вставляем

Код: php
$newPost = array();
        foreach($post as $k => $v){
            if(is_array($v) && strpos($k,'extra_field')!== false){
                $newPost[$k] = implode(',', $v);
            }
            else{
                $newPost[$k] = $v;
            }
        }

3. БД сделать запрос
Код: sql
ALTER TABLE `jos_jshopping_products` CHANGE `extra_field_1` `extra_field_1` VARCHAR( 255 ) NOT NULL
естественно поменять префикс таблиц на свой,и ко всем полям, содержащим в названии extra_field. Иначе будет запоминаться только первое выбранное значение.

Морда
\components\com_jshopping\tables\product.php

Код: php
        foreach($fields as $field_id){
            $field_name = "extra_field_".$field_id;
            if ($this->$field_name!=0){
                $rows[] = array("name"=>$listfield[$field_id]->name, "value"=>$fieldvalues[$this->$field_name]);
            }
        }

Меняем на
Код: php
        foreach($fields as $field_id){
            $field_name = "extra_field_".$field_id;
            if ($this->$field_name!=0){
                //экомир добавил мультихарактеристики
                $fvalues = explode(',', $this->$field_name);
                if(count($fvalues)>1){
                    $fstring = array();
                    foreach($fvalues as $fvalue){
                        $fstring[] = $fieldvalues[$fvalue];
                    }
                    $fstring = implode(', ', $fstring);
                    $rows[] = array("name"=>$listfield[$field_id]->name, "value"=>$fstring);
                }
                else{
                    $rows[] = array("name"=>$listfield[$field_id]->name, "value"=>$fieldvalues[$this->$field_name]);
                }

            }
        }

Отбор товаров по мультихарактеристикам


Скоро
« Последнее редактирование: 03.01.2012, 14:36:13 от Arkadiy »
*

nevigen

  • Moderator
  • 10451
  • 863 / 25
  • http://n*****n.com
Т.е. чтобы правильно понимать...
Это возможнсть присвоения нескольких характеристик товару имено в админке ?
А сама возможность фильтеринга с фронта будет "Скоро" ?

Супер !
Давно думал об этом.. но.. уповать приходилось только на разработчиков..
Однако теперь понимаю, что не только на них ;)
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Вышла 3.3.0, если бы не этот факт, то доделал бы завтра, но завтра придется делать ревизию компонента и совмещать правки и новый компонент, но думаю завтра-же и решу.
*

fliginskih

  • Захожу иногда
  • 197
  • 15 / 1
блин, ребята, давайте правильно выражаться!
ибо я боюсь неправильно вас понять.
не путайте характеристику с опцией ! есть характеристика "цвет" и ее опции "зеленый, синий и т.д."

так что же вы имеете в виду?
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
У меня терминология от вирта осталась, там все несколько по-другому, привыкнешь.
*

fliginskih

  • Захожу иногда
  • 197
  • 15 / 1
проверим, испытаем...
*

RUslankaRU

  • Новичок
  • 4
  • 0 / 0
Большое спасибо за проделанную работу, очень помогло.
Правда, есть нюанс. Не работал скрипт, пока не внесла после пункта 2 в вашем посте строку:
Код
 $post = $NewPost; 

Поиск joomla_module_JoomShopping-Search-3.1.2 прекрасно работает с вашим патчем.
*

leopoldus

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
 делаю SQL запрос
Код
ALTER TABLE `d1x3p_jshopping_products` CHANGE `extra_field_1` `extra_field_1` VARCHAR( 255 ) NOT NULL
и мне пишет #1054 - Unknown column 'extra_field_1' in 'd1x3p_jshopping_products' Прилагаю скриншот. Подскажите пожалуйста
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
делаю SQL запрос
Код
ALTER TABLE `d1x3p_jshopping_products` CHANGE `extra_field_1` `extra_field_1` VARCHAR( 255 ) NOT NULL
и мне пишет #1054 - Unknown column 'extra_field_1' in 'd1x3p_jshopping_products' Прилагаю скриншот. Подскажите пожалуйста
Заведите сначала в настройках магазина одну характеристику.
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
*

leopoldus

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
Цитировать
Заведите сначала в настройках магазина одну характеристику.
Сделал - все осталось также.
 У меня были с десяток характеристик, но я все же создал новую и подключил в настройка.

 Получается что сам мультивыбор в характеристиках есть, он выберает с контролом несколько пунктов, НО НЕ СОХРАНЯЕТСЯ
*

leopoldus

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
Цитировать
и ко всем полям, содержащим в названии extra_field.

Как это сделать в PHP My Admin
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
Данный SQL-запрос увеличивает ширину строки до 255 символов.
Посмотрите в таблице d1x3p_jshopping_products последние поля. Если есть характеристики, то это обычно extra_field_idхарактеристики.
Так вот для каждой характеристики которая будет "мультиселект", надо сделать такой запрос. А лучше использовать улучшенную версию Мультивыбора.
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться