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

e-Claire

  • Захожу иногда
  • 55
  • 0 / 0
Профи, подскажите, пожалуйста....

Есть модуль меню который выводится в стиле rounded, то есть четыре вложенных дива, в которых уже ненумерованный список.
Мне нужно каждому диву присвоить свой класс. В какой php файл лезть, чтобы это сделать?

Заранее спасибо!
*

Shustry

  • Moderator
  • 6434
  • 745 / 3
Ну во-первых, тут не нужно никуда лезти. Используйте каскадирование css:
Код: css
div {color:#fff} /*у дива и всех вложенных будет белый текст*/
div div {color:#000} /*а теперь чёрный*/
div div div {color:#fff} /*снова белый*/
div div div div {color:#fff} /*красный*/
А во-вторых, это уже устаревшая разметка. Раньше использовалась для скругления углов. Теперь так пишем:
Код: css
div {border-radius:3px;}
*

e-Claire

  • Захожу иногда
  • 55
  • 0 / 0
Ну во-первых, тут не нужно никуда лезти. Используйте каскадирование css:
Код: css
div {color:#fff} /*у дива и всех вложенных будет белый текст*/
div div {color:#000} /*а теперь чёрный*/
А во-вторых, это уже устаревшая разметка. Раньше использовалась для скругления углов. Теперь так пишем:
Код: css
div {border-radius:3px;}

Спасибо за ответ. Но это мне не для скругления углов нужно было. Просто в изначальном HTML документе, из которого я делала шаблон были прописаны стили сss разные для каждого вложенного блока.
И при изменении в CSS классов на просто div div {}, получалось, что свойства внешнего дива передаютя внутренним дивам, а этого как раз нужно было избежать.

В итоге сделала свою обертку для позиции модуля:
создала файл modules.php в папке templates/мой_шаблон/html/ с кодом:
Код
<?php
 
defined( '_JEXEC' ) or die;
 
function modChrome_myPosition( $module, &$params, &$attribs )
{
    if ( !empty ( $module->content ) ) {
        ?>
        <div class="class1">
            <div class="class2">
                <div class="class3"><?php echo $module->content; ?></div>
            </div>
        </div>
        <?php
    }
}

И вставила в свой шаблон якорь
Код
<jdoc:include type="modules" name="module name" style="myPosition" />
*

Shustry

  • Moderator
  • 6434
  • 745 / 3
Ну всё верно вы сделали. ^-^
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Пример создания модуля с прикреплением файлов

Автор Zelyonkin

Ответов: 7
Просмотров: 1108
Последний ответ 02.08.2021, 17:04:15
от Zelyonkin
Отображение модуля меню на странице материала

Автор kunsaid

Ответов: 9
Просмотров: 1242
Последний ответ 21.07.2021, 10:50:29
от kunsaid
[Решено] CSS-класс заголовка модуля

Автор schel4ok

Ответов: 36
Просмотров: 18730
Последний ответ 06.04.2021, 23:35:20
от Wak
Добавление модуля в шапку

Автор Bazaroff

Ответов: 8
Просмотров: 813
Последний ответ 18.01.2021, 19:59:58
от AlexB
Проблемы с ajax при выводе модуля

Автор Lemonez

Ответов: 6
Просмотров: 790
Последний ответ 21.12.2020, 05:16:55
от draff