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

pawana

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Запрос к другой БД
« : 15.02.2015, 15:13:01 »
Доброго времени суток всем.

Есть несколько магазинов на JoomShopping (сервер один), нужно чтобы все магазины обращались к одной базе (скажем так к базе основного магазина или, как вариант, к отдельной БД - с теми же таблицами и полями) при получении данных об остатке и при изменении этого остатка (т.е. чтобы при покупке товара в любом магазине остаток уменьшался только в одной базе).

Может кто знает в какие файлы нужно вносить изменения и как это лучше сделать.

Заранее благодарю за ответ.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Запрос к другой БД
« Ответ #1 : 15.02.2015, 16:13:26 »
Не советую, проще написать синхронизирующий 2 БД скрипт.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

pawana

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: Запрос к другой БД
« Ответ #2 : 15.02.2015, 17:20:24 »
Не советую, проще написать синхронизирующий 2 БД скрипт.
Мне от одной мысли страшно  ;D. Дело в том, что товар на разных сайтах один, а вот цены, описания да и настройки на сайтах разные. Синхронизировать можно только одно поле в одной таблице, да и то уж очень это навороченно...
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Запрос к другой БД
« Ответ #3 : 15.02.2015, 19:36:48 »
а от этой не страшно? :)
нужно чтобы все магазины обращались к одной базе
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pawana

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: Запрос к другой БД
« Ответ #4 : 15.02.2015, 20:13:58 »
а от этой не страшно? :)
Если бы не было страшно, то не писал-бы на форум... ^-^
Хорошо, если предположить, что скрипт будет синхронизировать базы, то такой скрипт, по-идее, нужно вставить где-то в чекауте, чтобы после сохранения заказа шла синхронизация с другими базами. И так не каждом сайте?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Запрос к другой БД
« Ответ #5 : 15.02.2015, 20:54:13 »
да, на каждом сайте. а в любом случае, какой путь решения вы не выбрали бы - надо будет делать на каждом сайте.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pawana

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: Запрос к другой БД
« Ответ #6 : 15.02.2015, 21:06:53 »
Спасибо, буду пробовать...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вернуть запрос из базы по Ajax в плагине.

Автор Dolphin4ik_1

Ответов: 2
Просмотров: 615
Последний ответ 04.12.2022, 09:56:52
от kit2m2
Сформировать запрос

Автор ShopES

Ответов: 1
Просмотров: 935
Последний ответ 24.05.2021, 13:51:35
от ShopES
Теряется ajax запрос cart add

Автор jrmobile

Ответов: 3
Просмотров: 1002
Последний ответ 10.03.2020, 09:00:10
от draff
При покупке одного товара, автоматически добавить другой

Автор frag79

Ответов: 9
Просмотров: 1552
Последний ответ 14.12.2019, 12:14:41
от frag79
Другой шаблон для всех товаров

Автор Ragivort

Ответов: 2
Просмотров: 769
Последний ответ 26.06.2019, 13:28:06
от Ragivort