Новости 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 Гость просматривают эту тему.
  • 4 Ответов
  • 1096 Просмотров
*

avantyrist

  • Захожу иногда
  • 228
  • 3 / 0
Ошибка после сортировки
« : 30.04.2015, 14:55:07 »
Добрый день, заметил проблему:
Сортировка стандартная не модуль:

в Категории отсортировав товар по ЦЕНЕ  перехожу в карточку товара, а там ошибка:

Цитировать
#1054 Unknown column 'cr.currency_value' in 'order clause' SQL=SELECT *, `prod`.`name_ru-RU` as name FROM `qy8l0_jshopping_products` AS prod INNER JOIN `qy8l0_jshopping_products_to_categories` AS pr_cat ON `pr_cat`.`product_id` = `prod`.`product_id` LEFT JOIN `qy8l0_jshopping_categories` AS cat ON `pr_cat`.`category_id` = `cat`.`category_id` WHERE `prod`.`product_publish` = 1 AND `pr_cat`.`category_id` = 2 ORDER BY prod.product_price/cr.currency_value ASC

Если сортировать по остальным параметрам то проблем нету

Помогите пожалуйста,  что ето всё означает, куда нада копать
« Последнее редактирование: 30.04.2015, 15:12:57 от avantyrist »
*

avantyrist

  • Захожу иногда
  • 228
  • 3 / 0
Re: Ошибка после сортировки
« Ответ #1 : 30.04.2015, 16:01:42 »
Блин ета ошибка вызвана Кодом "Кнопок Предыдущий-Следующий товар"

Спойлер
[свернуть]

Если закоментировать вот ето:
 /*  ЕТО ЗАКОМЕНТИРОВАЛ ИЗЗА ОШБКИ, ВОЗНИКАЮШЕЙ ПОСЛЕ СОРТИРОВКИ ПО ЦЕНА
 if ($jshopConfig->product_list_show_min_price){
 $field_order = "prod.min_price/cr.currency_value";
 }else{
 $field_order = "prod.product_price/cr.currency_value";
 }
 */
То ошибка пропадает,  Но что етот код делает, я не могу понять
*

Biss

  • Давно я тут
  • 995
  • 101 / 0
*

avantyrist

  • Захожу иногда
  • 228
  • 3 / 0
Re: Ошибка после сортировки
« Ответ #3 : 30.04.2015, 16:40:48 »
Таки да, Заработало
".$adv_from."
Если бы ешё понять что ето означает :)
*

Biss

  • Давно я тут
  • 995
  • 101 / 0
Re: Ошибка после сортировки
« Ответ #4 : 30.04.2015, 16:51:47 »
по ходу это добавлено в последних версиях. без этого - никак ^-^
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Ошибка при установке шаблона

Автор jimka

Ответов: 2
Просмотров: 1940
Последний ответ 23.08.2023, 15:22:52
от victorantoniak
JoomShopping умер после обновления

Автор Alex_gs

Ответов: 3
Просмотров: 1071
Последний ответ 08.05.2023, 15:02:11
от Akeksandr
JoomShopping 5.1.1 ошибка Undefined constant &quot;_JSHOP_ORDER_BY&quot;

Автор webaster

Ответов: 6
Просмотров: 1360
Последний ответ 07.01.2023, 13:42:11
от kit2m2
Ошибка при правке данных клиента и попытке отправить письмо из заказа

Автор ecolora

Ответов: 40
Просмотров: 2688
Последний ответ 17.09.2022, 20:06:26
от marksetter
Ошибка при добавлении фото товара на сайт JoomShopping

Автор Zacken

Ответов: 5
Просмотров: 1682
Последний ответ 16.09.2022, 23:23:52
от victorantoniak