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

dron

  • Завсегдатай
  • 1581
  • 16 / 10
Добрый день! Обновил Joomla + JS. Перешел с 2.5 + 3 на 3.5 + 4.

Админка работает, сайт работает, магазин работает, но только по попытке зайти в товар. При входе в товар выдается ошибка:

Код
1054 Unknown column 'A.group' in 'on clause' SQL=SELECT A.attr_id, A.`name_ru-RU` as name, A.`description_ru-RU` as description, A.attr_type, A.independent, A.allcats, A.cats, A.attr_ordering, G.`name_ru-RU` as groupname FROM `#__jshopping_attr` as A left join `#__jshopping_attr_groups` as G on A.`group`=G.id ORDER BY G.ordering, A.attr_ordering 

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

Заранее спасибо!
« Последнее редактирование: 21.04.2016, 15:45:23 от dron »
*

dmitry_stas

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

dron

  • Завсегдатай
  • 1581
  • 16 / 10
установите и запустите database checker с сайта разработчика, и исправьте ошибки в базе
Это какой-то dll'овский файл... Не пойму что с ним делать даже ((( А есть какие-то аналоги?
*

dmitry_stas

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

dron

  • Завсегдатай
  • 1581
  • 16 / 10
вы о чем? :) какой еще dll? :)
http://wiki.miranda-ng.org/index.php?title=Plugin:DbChecker/ru - блин. Не то скачал..... Нашел тот скрипт о котором Вы писали. Щас попробую.

Спасибо!
*

dron

  • Завсегдатай
  • 1581
  • 16 / 10
Всё! Разобрался! Помог аддон Check DB structure table shop, с официального сайта разработчика JoomShopping: https://www.webdesigner-profi.de/joomla-webdesign/shop/addons/check-db-structure-table-shop.html?lang=en Ставится через Установку и Обновление магазина. Находит ошибки и исправляет их.

Уважаемый dmitry_stas. Спасибо, что подсказали в какую сторону копать, но никакой database checker я так и не нашел (((
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
)))) а Check DB structure table shop - это что по вашему? :) не database checker с сайта разработчика? :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

dron

  • Завсегдатай
  • 1581
  • 16 / 10
Ну, скажем так, это не очевидно. Я, например, впервые о нем слышал )
*

nevigen

  • Moderator
  • 10451
  • 863 / 25
  • http://n*****n.com
Ну, скажем так, это не очевидно. Я, например, впервые о нем слышал )
а если во второй раз услышите будет уже очевидно ?
от того что Вы не знаете как выглядит ключ на 19", он не становится не очевидным ;)
а при постоянной работе с гаечными ключами, у Вас отпадет потребность смотреть что на них написано...
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
*

dron

  • Завсегдатай
  • 1581
  • 16 / 10
Можно сказать:
1. Возьмите ключ
2. Возьмите ключ на 19
3. Возьмите ключ на 19, который лежит в красном ящике с инструментами на балконе

В конкретном случае реальное название утилиты Check DB structure table shop совершенно не ассоциировалось с упомянутой database checker.

В любом случае, проблема решена и я благодарен за наводку.

Кстати, сам я, решив проблему, описал её точное решение, что, возможно поможет кому-то в будущем. И использовал именно 3 вариант упомянутого мной выше разъяснения. Согласитесь, это гораздо понятнее.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Ну, скажем так, это не очевидно.
Ну, одно очевидно: для вас "database checker" - то же самое, что для меня "數據庫檢查" :).
Не будь паразитом, сделай что-нибудь самостоятельно!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

После оформления заказа письма не приходят ни покупателю ни админу

Автор goga_pgasovav

Ответов: 8
Просмотров: 1315
Последний ответ 10.04.2025, 07:38:04
от kit2m2
[Решено] Не удаляются товары из корзины (Multi basket ajax)

Автор goga_pgasovav

Ответов: 0
Просмотров: 1197
Последний ответ 14.08.2024, 23:19:57
от goga_pgasovav
Ошибки магазина (2015)

Автор nevigen

Ответов: 162
Просмотров: 17579
Последний ответ 02.06.2024, 22:02:55
от Vastriet
Ошибка при изменении статуса товара

Автор itbc

Ответов: 4
Просмотров: 1346
Последний ответ 08.05.2024, 10:31:16
от itbc
Ошибка при заполнении поля Улица/Номер дома. Как исправить ошибку?

Автор admi5575

Ответов: 9
Просмотров: 1629
Последний ответ 10.05.2023, 07:21:14
от admi5575