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

IlyaJom

  • Осваиваюсь на форуме
  • 45
  • 0 / 0
Предисловие: На Joomla стоял отдельный плагин для lightbox. Но шаблон на UIkit3. С недавнего времени стал изучать UIkit, и увидел там неплохой lightbox., решил избавиться от плагина и внедрить встроенный в UIkit3 lightbox.

В документации написано

<div uk-lightbox>
    <a href="image.jpg" data-caption="Caption"></a>
</div>


Но не хочется каждую картинку оборачивать в div, так как на страницах их много. В итоге "uk-lightbox" я прописал для контейнера всей статьи, но в lightbox стали подгружаться и простые ссылки.

Как инициализировать UIkit.lightbox , чтобы он применялся только к ссылкам с определенным классом?

Что можно сделать? спасибо
*

dmitry_stas

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

dm-krv

  • Завсегдатай
  • 1028
  • 28 / 0
Несколько месяцев назад столкнулся с такой же проблемой) Удалось решить при помощи небольшого самописного скрипта. Выведите на страницах, где картинки ваши, следующий код:
Код
<script type="text/javascript">
var image = document.querySelectorAll("article img");

for(var i = 0; i < image.length; i++) {
    image[i].addEventListener('click', function(e) {
        openpict(this.getAttribute('src'));
    });
}

function openpict(src) {
image.src = src;
    UIkit.lightbox.create([ {'source': src, 'type':'image'} ]).show();
}
</script>
При клике на любую картинку внутри блока article эта картинка будет открываться в Lightbox.
« Последнее редактирование: 10.03.2019, 11:15:56 от dm-krv »
*

IlyaJom

  • Осваиваюсь на форуме
  • 45
  • 0 / 0
Несколько месяцев назад столкнулся с такой же проблемой) Удалось решить при помощи небольшого самописного скрипта. Выведите на страницах, где картинки ваши, следующий код:
Код
<script type="text/javascript">
var image = document.querySelectorAll("article img");

for(var i = 0; i < image.length; i++) {
    image[i].addEventListener('click', function(e) {
        openpict(this.getAttribute('src'));
    });
}

function openpict(src) {
image.src = src;
    UIkit.lightbox.create([ {'source': src, 'type':'image'} ]).show();
}
</script>
При клике на любую картинку внутри блока article эта картинка будет открываться в Lightbox.


попробую! Благодарю
*

IlyaJom

  • Осваиваюсь на форуме
  • 45
  • 0 / 0
Несколько месяцев назад столкнулся с такой же проблемой) Удалось решить при помощи небольшого самописного скрипта. Выведите на страницах, где картинки ваши, следующий код:
Код
<script type="text/javascript">
var image = document.querySelectorAll("article img");

for(var i = 0; i < image.length; i++) {
    image[i].addEventListener('click', function(e) {
        openpict(this.getAttribute('src'));
    });
}

function openpict(src) {
image.src = src;
    UIkit.lightbox.create([ {'source': src, 'type':'image'} ]).show();
}
</script>
При клике на любую картинку внутри блока article эта картинка будет открываться в Lightbox.


Попробовал.

Увы, НЕ сработало. Все равно, любые ссылки в article грузит в Lightbox

вот тестировал:
https://codepen.io/ilya-vins/pen/jJwzvy
*

dm-krv

  • Завсегдатай
  • 1028
  • 28 / 0
Скрипт выше просто не заточен на загрузку ссылок, это уже ваш шаблон чудит или еще что.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как вывести Alt картинки в описание Lightbox?

Автор art22

Ответов: 2
Просмотров: 2509
Последний ответ 14.05.2023, 09:21:39
от sivers
Вопрос по настройке Helix3

Автор AleksS

Ответов: 644
Просмотров: 108778
Последний ответ 16.03.2023, 21:36:56
от SolopoV
Helix ultimate 2 вопрос про меню и хедар

Автор Serganius

Ответов: 3
Просмотров: 1264
Последний ответ 21.12.2021, 23:02:51
от Alex_gs
Master3 – современный удобный гибкий шаблон для Joomla! 3 на фреймворке UIkit 3

Автор dron

Ответов: 81
Просмотров: 10727
Последний ответ 11.09.2021, 03:12:59
от vasileк
вопрос по шаблону DD Garden для Joomla 3

Автор Tatyana.

Ответов: 50
Просмотров: 3787
Последний ответ 13.04.2021, 07:14:37
от IToro82