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

odin2000

  • Осваиваюсь на форуме
  • 28
  • 3 / 0
Привет. Значит вопрос. Есть главная категория (maincategory.php) вот как из нее получить дочерние категории из текущих, делал прямые запросы но не могу получить получить поле name_ru-RU выводит нолик, уже запарился ;D хочу сделать по аналогии с http:// dns-shop.ru/catalog/
*

dmitry_stas

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

odin2000

  • Осваиваюсь на форуме
  • 28
  • 3 / 0
Да обычный кусочек вот, просто пытаюсь вывести поле (name_ru-RU)
Код
$db = JFactory::getDBO();
$query = "SELECT * FROM #__jshopping_categories WHERE category_parent_id=1";
$db->setQuery($query);
if( $rows = $db->loadObjectList() )
{
  foreach( $rows as $row )
  {
    echo $row->name_ru-RU;
  }
}
Тут выводит нолик ^^
Сайтец не могу показать, ибо на локалке. В принципе нужно только както получить это поле не извращаясь, а дальше уже изи :3
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
а что по вашему должно вывести $row->name_ru минус RU ? :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

odin2000

  • Осваиваюсь на форуме
  • 28
  • 3 / 0
)))) Спасибо, чет я совсем отупел ^^
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
Ну Дмитрий, как то Вы сильно критикуете...
Человек тут недавно, а названием полей типа "ru-RU" балуется в основном ЖШ...
Я во время изучения ЖШ, сам впирался в такие банальные штуки которые надо знать в области MySQL.
Поэтому решений тут несколько:
Код: php
$db = JFactory::getDBO();
$lang = JSFactory::getLang();
$query = "SELECT `".$lang->get("name")."` as name,* FROM #__jshopping_categories WHERE category_parent_id=1";
$db->setQuery($query);
if( $rows = $db->loadObjectList() )
{
  foreach( $rows as $row )
  {
    echo $row->name;
  }
}
Либо
Код: php
$db = JFactory::getDBO();
$query = "SELECT * FROM #__jshopping_categories WHERE category_parent_id=1";
$db->setQuery($query);
if( $rows = $db->loadObjectList() )
{
  foreach( $rows as $row )
  {
    $name = JSFactory::getLang()->get("name");
    echo $row->$name;
  }
}
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Цитировать
Ну Дмитрий, как то Вы сильно критикуете...
я не критикую, а навожу на мысль :) причем насколько я понял по ответу, навожу правильно :)

Цитировать
Поэтому решений тут несколько
также есть $row->{'name_ru-RU'}
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться