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

mbb

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
SQL запрос
« : 02.08.2016, 17:06:05 »
Как сформировать запрос SQL
Получить все id товаров из определенной категории, если у этой категории есть подкатегории то и ID товаров из всех подкатегорий. 
Спасибо.
*

mbb

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Re: SQL запрос
« Ответ #1 : 03.08.2016, 11:42:26 »
Как просто получить все id товаров из определенной категории ?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: SQL запрос
« Ответ #2 : 03.08.2016, 11:58:54 »
посмотрите \components\com_jshopping\tables\category.php function getProducts
« Последнее редактирование: 03.08.2016, 12:03:13 от dmitry_stas »
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

mbb

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Re: SQL запрос
« Ответ #3 : 03.08.2016, 14:34:19 »
посмотрите \components\com_jshopping\tables\category.php function getProducts

От туда и собрал запрос например для категории id = 38

Код
$query = "SELECT prod.product_id, pr_cat.category_id FROM `khwld_jshopping_products` AS prod
                  INNER JOIN `khwld_jshopping_products_to_categories` AS pr_cat ON pr_cat.product_id = prod.product_id
                  LEFT JOIN `khwld_jshopping_categories` AS cat ON pr_cat.category_id = cat.category_id
                  WHERE prod.product_publish=1 AND cat.category_publish=1 AND cat.category_id = 38
                  GROUP BY prod.product_id DESC
 LIMIT 200;";
 
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Запрос активации учетной записи {name} на сайте {sitename}

Автор ecolora

Ответов: 14
Просмотров: 1203
Последний ответ 30.05.2022, 00:33:31
от ProtectYourSite
Как правильно дополнить запрос к таблице товаров чтобы вывести значение из базы данных в список това?

Автор kit2m2

Ответов: 7
Просмотров: 1188
Последний ответ 25.09.2016, 08:19:22
от dmitry_stas
Запрос на выборку товаров с метками

Автор tomas_morgam

Ответов: 1
Просмотров: 842
Последний ответ 05.07.2016, 16:41:43
от Linfuby
Помочь дописать запрос на выборку с БД для экспорта

Автор tomas_morgam

Ответов: 4
Просмотров: 1363
Последний ответ 31.05.2016, 09:13:36
от tomas_morgam
Уважаемые знатоки, запрос к БД(

Автор Begotten

Ответов: 4
Просмотров: 933
Последний ответ 02.02.2015, 10:51:24
от Linfuby