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

TheOne

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
День добрый. Заранее прошу прощения, если создал тему не в том разделе. Есть сайт на Joomla 2.5+Joomshopping. При нажатии на фотографию товара, картинка увеличивается во весь экран и ее надо прокручивать. До этого был глюк, когда картинка не увеличивалась, а просто отображалась в том же размере, но в углу экрана. Хотелось бы, чтобы картинка увеличивалась и оставалась в центре экрана, поверх сайта. Думаю понимаете о чем я.Подскажите ПОЖАЛУЙСТА, как решить эту проблему. Утомился уже. Переставил сайт и опять этот глюк.
*

shurakana

  • Давно я тут
  • 792
  • 50 / 6
Я уже где то писал, что скорее всего у тебя проблема в 18 строке, 4-го сверху файла, который лежит в 9-й снизу папке..

Может все таки ссылку предоставите?)
Эта подпись отображается внизу каждого Моего сообщения. Я также могу использовать BB код и смайлы.
*

TheOne

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
i-market.in
*

TheOne

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
очень надеюсь, что поможете.
*

shurakana

  • Давно я тут
  • 792
  • 50 / 6
Ц, вы могли сразу скинуть ссылку на проблемное место? Я в 5 категориях побывал, товара не обнаружил..))

Думаю еще один ваш такой номер, и можно уже материться..
Эта подпись отображается внизу каждого Моего сообщения. Я также могу использовать BB код и смайлы.
*

TheOne

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Да, конечно. http://i-market.in/index.php/magazin/product/view/22/1. Зашел с телефона, картинка увеличивается не во весь экран, а в маленьком окне и с низким разрешением
*

shurakana

  • Давно я тут
  • 792
  • 50 / 6
Да уж.. Вообще, все нормально, дело в мобильном устройстве.
Есть такое понятие, как адаптация для мобильных устройств. Почитайте.
Эта подпись отображается внизу каждого Моего сообщения. Я также могу использовать BB код и смайлы.
*

TheOne

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Не знаю. Просто у меня одна фотография увеличивается нормально, другие во весь экран с прокруткой. Это на компьютере.
*

shurakana

  • Давно я тут
  • 792
  • 50 / 6
моя твоя не понимать
Эта подпись отображается внизу каждого Моего сообщения. Я также могу использовать BB код и смайлы.
*

TheOne

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Ниже код элемента для двух фотографий товара:

<div id="lightbox-container-image-box" style="width: 820px; height: 469px;"><div - это та фотография, которая увеличивается нормально.

<div id="lightbox-container-image-box" style="width: 4020px; height: 2268px;"><div - а это другая, она как раз во весь экран выводится, с элементами прокрутки.

Почему фотографии, загруженные с одинаковыми параметрами, увеличиваются по-разному?
« Последнее редактирование: 30.08.2014, 19:59:35 от TheOne »
*

TheOne

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Решил установкой плагина jqzoom. Спасибо.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Увеличение full изображения

Автор Simply

Ответов: 4
Просмотров: 819
Последний ответ 13.04.2025, 12:46:05
от victorantoniak
Уведомление о превышении доступного количества товара

Автор goga_pgasovav

Ответов: 1
Просмотров: 838
Последний ответ 03.02.2025, 18:48:10
от kit2m2
Артикул или код товара?

Автор goga_pgasovav

Ответов: 3
Просмотров: 1085
Последний ответ 28.11.2024, 19:03:59
от goga_pgasovav
Странная задача: получить псевдоним товара по его ID в шаблоне статьи

Автор goga_pgasovav

Ответов: 4
Просмотров: 1542
Последний ответ 04.07.2024, 13:06:45
от goga_pgasovav
Ошибка при изменении статуса товара

Автор itbc

Ответов: 4
Просмотров: 1346
Последний ответ 08.05.2024, 10:31:16
от itbc