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

burunduchok

  • Захожу иногда
  • 106
  • 8 / 0
После попытки разместить товар в несколько категорий получаю ошибку:
Код
Duplicate entry '1' for key 'product_id_2' SQL=INSERT INTO `jos_jshopping_products_to_categories` SET `product_id` = '1', `category_id` = '1', `product_ordering` = '1'
Как с ней разобраться?
*

kocius

  • Осваиваюсь на форуме
  • 24
  • 0 / 0
Может проблема в ID категорий (должны быть разные)? ID товаров все равно одинаковое
*

burunduchok

  • Захожу иногда
  • 106
  • 8 / 0
Этот товар записан в другую категорию
*

burunduchok

  • Захожу иногда
  • 106
  • 8 / 0
Разобрался сам, разница была вот в чем.
Текущее состояние таблицы:
Код
CREATE TABLE IF NOT EXISTS `jos_jshopping_products_to_categories` (
  `product_id` int(11) NOT NULL,
  `category_id` int(11) NOT NULL,
  `product_ordering` int(11) NOT NULL,
  PRIMARY KEY (`product_id`,`category_id`),
  UNIQUE KEY `product_id_2` (`product_id`),
  UNIQUE KEY `product_id_3` (`product_id`),
  UNIQUE KEY `product_id_4` (`product_id`),
  UNIQUE KEY `product_id_6` (`product_id`),
  KEY `category_id` (`category_id`),
  KEY `product_id` (`product_id`),
  KEY `category_id_2` (`category_id`),
  KEY `product_id_5` (`product_id`),
  KEY `category_id_3` (`category_id`),
  KEY `product_ordering` (`product_ordering`),
  KEY `category_id_4` (`category_id`),
  KEY `product_id_7` (`product_id`),
  KEY `product_id_8` (`product_id`),
  KEY `category_id_5` (`category_id`),
  KEY `product_ordering_2` (`product_ordering`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
Оригинальная:
Код
CREATE TABLE IF NOT EXISTS `jos_jshopping_products_to_categories` (
  `product_id` int(11) NOT NULL,
  `category_id` int(11) NOT NULL,
  `product_ordering` int(11) NOT NULL,
  PRIMARY KEY (`product_id`,`category_id`),
  KEY `category_id` (`category_id`),
  KEY `product_id` (`product_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
В общем наклацал я :)
Вопрос решен!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

WT On fly image handler изображения товара JoomShopping в webp на лету

Автор sergeytolkachyov

Ответов: 13
Просмотров: 4374
Последний ответ 29.01.2025, 20:38:38
от sergeytolkachyov
Видео с Youtube вместо картинки на карточке товара

Автор ksena

Ответов: 35
Просмотров: 10210
Последний ответ 08.10.2024, 04:26:36
от kit2m2
Сообщение о добавлении

Автор Harper

Ответов: 15
Просмотров: 44740
Последний ответ 16.06.2024, 23:14:52
от victorantoniak
[JoomShopping 5] вывод товаров из дочерних категорий

Автор v42bis

Ответов: 15
Просмотров: 2666
Последний ответ 14.06.2024, 11:43:28
от denistischenko
Условие для кол-ва товара больше нуля

Автор kik84

Ответов: 3
Просмотров: 1335
Последний ответ 16.02.2024, 13:33:24
от kit2m2