Новости 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 Ответов
  • 1046 Просмотров
*

pvi1

  • Давно я тут
  • 566
  • 16 / 2
Делаю запрос в базу
UPDATE `название таблицы` SET `description_en-GB` = REPLACE( description_en-GB, 'старое описание', 'новое описание' ) ;
Выдает ошибку "#1054 - Unknown column 'description_en' in 'field list'. Догадываюсь, что проблема в окончании "-GB", но как ее решить?
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Всегда оборачивайте названия в апострофы. MySQL воспринимает "-" как минус.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

pvi1

  • Давно я тут
  • 566
  • 16 / 2
Если оборачиваю в апостроф, в описании записывается только текст "description_en-GB". Сам текст нового описания не записывается.
Или попробовать обернуть только "-"?
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Код: sql
UPDATE `название таблицы` SET `description_en-GB`= REPLACE(`description_en-GB`,'старое описание','новое описание')
должен работать.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

pvi1

  • Давно я тут
  • 566
  • 16 / 2
Сработало. Спасибо. Виной было отсутствие апострофа в конце нового описания.
« Последнее редактирование: 29.07.2015, 19:00:13 от pvi1 »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Массовое добавление и изменение товаров JoomShopping

Автор kaballesha

Ответов: 2
Просмотров: 847
Последний ответ 27.12.2021, 11:27:49
от kaballesha
Изменение шаблона для списка товаров

Автор Spawned

Ответов: 1
Просмотров: 583
Последний ответ 28.01.2021, 18:06:11
от kit2m2
Ссылка на полноразмерное (full) изображение продукта в каталоге (list_products)

Автор goga_pgasovav

Ответов: 8
Просмотров: 1058
Последний ответ 14.04.2020, 14:09:29
от goga_pgasovav
Массовое редактирование цен товаров валюта

Автор misteri27

Ответов: 5
Просмотров: 1883
Последний ответ 04.02.2020, 23:00:57
от misteri27
Изменение структуры url для новостной ленты и производителей JoomShopping

Автор nikwww

Ответов: 21
Просмотров: 1121
Последний ответ 24.12.2019, 12:41:22
от kit2m2