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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Прошу помочь исправить запрос
Код
$db = JFactory::getDbo();
$query = "SELECT `name_ru-RU` , `product_price` , `product_thumb_image` FROM `#__jshopping_products` AS prod LEFT JOIN `#__jshopping_products_to_categories` AS pr_cat ON pr_cat.`product_id` = prod.`product_id` WHERE pr_cat.category_id = $this->category_id";
$db->setQuery($query);
$results = $db->loadObjectList();
print_r($results);
foreach($results as $attr) {
echo $attr->name_ru-RU."</b> ".$attr->product_thumb_image." ".$attr->product_price."<br />";
}
Не хочет выводить название товара
Код
0 thumb_71d03965edad97ff6cd5d153bf512002.jpg 1000.000000
Хотя когда вывожу результаты запроса через print_r название есть
Код
Array
(
    [0] => stdClass Object
        (
            [name_ru-RU] => Синее кресло
            [product_price] => 1000.000000
            [product_thumb_image] => thumb_e9fe4a422bb63677b4dd6eeee763ce89.jpg
        )
)
*

SDKiller

  • Живу я здесь
  • 2705
  • 329 / 5
  • ...ergo sum
Используйте алиас для name_ru-RU, например так:

Код
...
$query = "SELECT `name_ru-RU` AS product_name, `product_price` ,...
...

И соответственно

Код
foreach($results as $attr) { 
echo $attr->product_name ...
}
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Используйте алиас для name_ru-RU, например так:

Код
...
$query = "SELECT `name_ru-RU` AS product_name, `product_price` ,...
...

И соответственно

Код
foreach($results as $attr) { 
echo $attr->product_name ...
}
Большое спасибо! Действительно забыл прикрепить к переменной через AS.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Проблемы с корзиной при больших заказах

Автор anny_k

Ответов: 12
Просмотров: 879
Последний ответ 06.04.2020, 22:50:20
от nevigen
Ошибочный ответ запроса базы данных: ErrNo #0

Автор Taatshi

Ответов: 5
Просмотров: 1893
Последний ответ 11.02.2017, 13:08:15
от dmitry_stas
Проблемы с увеличением изображения товара

Автор TheOne

Ответов: 10
Просмотров: 1426
Последний ответ 30.08.2014, 20:07:20
от TheOne
Проблемы с изображениями (несколько)

Автор web-nino

Ответов: 11
Просмотров: 1437
Последний ответ 15.08.2014, 14:34:22
от sergoguga
Непонятые проблемы со страницей товаров с меткой.

Автор denxio

Ответов: 2
Просмотров: 1178
Последний ответ 11.02.2014, 15:58:54
от denxio