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

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
В админке JoomShopping где список товаров не разворачивается сам список с товарами. В чем может быть проблема?
*

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
У кого нибудь такое было? Не могу выбрать сопутствующий товар, т.к. показывает только кол-во страниц, а самого списка товара нет.
*

SDKiller

  • Живу я здесь
  • 2705
  • 329 / 5
  • ...ergo sum
Какие-нибудь дополнительные плагины ставили?

Включите режим отладки в Joomla - возможно покажет какую-нибудь ошибку в sql-запросе
*

ELLE

  • Глобальный модератор
  • 4505
  • 893 / 0
а если кол-во строк выбрать Все? и потыкать туда-сюда
*

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
Спасибо что откликнулись!
Включил режим отладки показывает ошибку, только я не очень понимаю в чем именно, как я понял что-то связано с максимальным размером

JDatabaseMySQLi::query: 1104 - The SELECT would examine more than MAX_JOIN_SIZE rows; check your WHERE and use SET SQL_BIG_SELECTS=1 or SET MAX_JOIN_SIZE=# if the SELECT is okay SQL=SELECT pr.product_id, pr.product_publish, pr.`name_ru-RU` as name, pr.`short_description_ru-RU` as short_description, man.`name_ru-RU` as man_name, GROUP_CONCAT(cat.`name_ru-RU` SEPARATOR '
') AS namescats, pr.product_ean as ean, pr.product_quantity as qty, pr.product_thumb_image as image, pr.product_price, pr.currency_id, pr.hits, pr.unlimited, pr.product_date_added, pr.label_id FROM `wox89_jshopping_products` AS pr LEFT JOIN `wox89_jshopping_products_to_categories` AS pr_cat USING (product_id) LEFT JOIN `wox89_jshopping_categories` AS cat ON pr_cat.category_id=cat.category_id LEFT JOIN `wox89_jshopping_manufacturers` AS man ON pr.product_manufacturer_id=man.manufacturer_id WHERE pr.parent_id=0 GROUP BY pr.product_id order by pr.product_id asc LIMIT 0 , 10

Поясните пожалуйста что не так?
Последний плагин ставил по бонусной системе.
*

SDKiller

  • Живу я здесь
  • 2705
  • 329 / 5
  • ...ergo sum
Последний плагин ставил по бонусной системе.

Попробуйте отключить.
Вряд ли вы сможете оперировать настройками мускула на хостинге - но можете попробовать обратиться в саппорт с вопросом об увеличении лимита MAX_JOIN_SIZE
*

SDKiller

  • Живу я здесь
  • 2705
  • 329 / 5
  • ...ergo sum
Кстати, уточните версии Joomla, JoomShopping

Какое количество товаров и категорий?
*

nevigen

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

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
Да, бонусная не причем, я её отключал (удалял), это скорее всего из-за большого кол-ва товаров, отправил запрос хостингу на увеличение лимита max_join_size.
Joomla 2.5.11
JoomShopping Version 3.14.3
Всего товаров: 14530

на "все" конечно же не ставил
*

SDKiller

  • Живу я здесь
  • 2705
  • 329 / 5
  • ...ergo sum
Всего товаров: 14530

Многовато уже будет для shared-хостинга, как минимум vds надо брать.
*

nevigen

  • Moderator
  • 10451
  • 863 / 25
  • http://n*****n.com
нууу у нас 40к ворочается.. на тестовом.. правда не активно только для тестов...
возможно если активное пользоваоние 14килотоваров то да
+ "оптимизированные" запросы
+ если шаред на 64Мб памяти то да..
будет туговато
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
*

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
Тех. поддер. хостинга ответила, что данное ограничение они не меняют, и следует использовать set sql_big_selects=1

Вот теперь вопрос куда его прописать?
Я так понимаю прописать нужно в файле MySQL.php (libraries/joomla/database/database) только подскажите пожалуйста куда.
*

SDKiller

  • Живу я здесь
  • 2705
  • 329 / 5
  • ...ergo sum
Вы с 15к товаров собираетесь под каждое ограничение хостинга делать хаки в ядре Joomla?

vds на хетцнере стоит дешевле чем некоторые тарифы на shared-хостинг в россии, при том что ресурсов больше
*

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
А почему бы и нет? Сайт сейчас только еще наполняется, допиливается, посетителей на сайте пока только до 40-ти в сутки.
Просто процесс наполнения может затянуться на пол года, а может и год и пока не хочется переплачивать за хостинг.
В будущем конечно же переедем на vds.
*

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
пожалуйстаз, подскажите куда прописать set sql_big_selects=1?
*

Mishani

  • Захожу иногда
  • 74
  • 1 / 0
Прикольно, на хостинге sweb поддерживает максимум 14 000 товаров, добавляю еще один товар список товаров исчезает.
Думаю пока будем придерживаться этого количества товара потом если захотим увеличить перейдем на VDS
*

viy

  • Захожу иногда
  • 54
  • 0 / 1
ну бонусная не причем ;)
а кол-во товаров нв страницк для отображение в админке какое ?
надеюсь не "все" ? при 100500 товарах

А если нажал "все"? и как теперь от этого избавиться?
*

dmitry_stas

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

Taatshi

  • Гуру
  • 5258
  • 481 / 2
  • Верстаем и кодим. Обращайтесь ;)
Цитировать
А если нажал "все"? и как теперь от этого избавиться?

Насколько понимаю, эта настройка не запоминается. Выйти из панели администратора и зайти снова - восстановится дефолт.
ВЕРСТКА, САЙТЫ ПОД КЛЮЧ, УДАЛЕНИЕ ВИРУСОВ, МИГРАЦИЯ НА JOOMLA 3, ОБНОВЛЕНИЕ  |  ОТЗЫВЫ 
Связь: telegram - Taatshi, почта - Taatshi на яндексе, Skype - Taatshi
*

viy

  • Захожу иногда
  • 54
  • 0 / 1
Насколько понимаю, эта настройка не запоминается. Выйти из панели администратора и зайти снова - восстановится дефолт.

запоминается, где-то в базе, не пойму где
« Последнее редактирование: 30.04.2015, 06:16:05 от viy »
*

viy

  • Захожу иногда
  • 54
  • 0 / 1
так select количества же вроде не должен пропасть. там и выбрать 20 например.
от большого количества выдает ошибку Fatal error: Allowed memory size of 33554432 bytes exhausted (tried to allocate 72 bytes) in /home/kukla/public_html/libraries/joomla/database/database/mysql.php on line 712
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ясно. тогда вам сюда: /administrator/index.php?option=com_jshopping&controller=products&category_id=0&limit=20
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

WT JoomShopping Favorite - кнопки избранного в категории товаров и карточке тов

Автор sergeytolkachyov

Ответов: 25
Просмотров: 35713
Последний ответ 23.09.2025, 11:22:23
от Alex_gs
Атрибуты полей при оформлении заказа в JoomShopping

Автор goga_pgasovav

Ответов: 1
Просмотров: 629
Последний ответ 12.08.2025, 11:21:29
от kit2m2
Конфликт js шаблонов JoomShaper helix3 J5 с JoomShopping 5

Автор heartlink

Ответов: 6
Просмотров: 1404
Последний ответ 22.07.2025, 12:40:12
от heartlink
Модуль карусели товаров JoomShopping на Swiper.js для Joomla

Автор sergeytolkachyov

Ответов: 2
Просмотров: 2049
Последний ответ 04.07.2025, 10:30:36
от sergeytolkachyov
[Решено] Сбросить счётчик ID товаров JoomShopping

Автор goga_pgasovav

Ответов: 3
Просмотров: 1359
Последний ответ 13.02.2025, 00:11:20
от goga_pgasovav