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

avantyrist

  • Захожу иногда
  • 228
  • 3 / 0
Добрый день.
Сейчас копаюсь с БД, возник вопрос по таблице   _jshopping_products_attr

Joomla 3,  JS Version 4.8.1
Поле count  имеет  тип decimal(14,4)     Для чего так ?? О_о    ,   разве количество может быть дробным числом ??  записи в етом поле такого вида 20.0000   15.0000      

в Joomla 2.5,  JS   Version 3.17.1
Поле count  имеет  тип int(11)  -- тут както правльнее  :), вродебы

И ешё:  что содержит в себе поле      ext_attribute_product_id
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Таблица в БД _jshopping_products_attr
« Ответ #1 : 30.05.2015, 15:37:26 »
разве количество может быть дробным числом ??

а что мешает ему быть дробным?

что содержит в себе поле ext_attribute_product_id

ссылку на таблицу _jshopping_products - если заданы Дополнительные значения для атрибута
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

avantyrist

  • Захожу иногда
  • 228
  • 3 / 0
Re: Таблица в БД _jshopping_products_attr
« Ответ #2 : 05.06.2015, 01:00:15 »
Во как получается,  При создании дополнительного значения атрибута, создаётся, какбы  ешё один товар, но "пустышка"  :o

ext_attribute_product_id   как раз и ссылается на ID етого товара "пустышки",

Я правильно понял ?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Таблица в БД _jshopping_products_attr
« Ответ #3 : 05.06.2015, 08:20:45 »
почему он пустышка? никакой он не пустышка. у него могут быть изображения, и тогда из таблицы images есть ссылки на этот product_id, и так далее.

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

avantyrist

  • Захожу иногда
  • 228
  • 3 / 0
Re: Таблица в БД _jshopping_products_attr
« Ответ #4 : 05.06.2015, 10:49:06 »
Не я пытаюсь фильтр написать по атрибутам  :o
Ну сам фильтр уже фильтрует:)   вот тока надо ешё кучу всего сделать в нём
*

sterveo

  • Захожу иногда
  • 60
  • 1 / 0
Re: Таблица в БД _jshopping_products_attr
« Ответ #5 : 08.11.2016, 05:12:21 »
Интересно а как сам компонент (JS) выводит целое число когда в таблице (столбик count) он 1.000, ну типа на складе 10 штук, а таблице написано 10.000 ?
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Таблица в БД _jshopping_products_attr
« Ответ #6 : 08.11.2016, 05:16:56 »
Очень просто, приводим это поле к типу float, этот тип не выводит нули после запятой.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Таблица в БД _jshopping_products_attr
« Ответ #7 : 08.11.2016, 09:44:39 »
если имеется в виду, где это в ЖШ, то \components\com_jshopping\lib\functions.php function formatqty
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Таблица атрибутов товара в карточке товара

Автор urry

Ответов: 2
Просмотров: 1225
Последний ответ 13.12.2016, 15:03:03
от Cerber
Таблица в описании товара

Автор paskal

Ответов: 5
Просмотров: 1144
Последний ответ 17.03.2014, 12:58:13
от paskal
Размерная таблица производителя

Автор jeka_808

Ответов: 7
Просмотров: 1540
Последний ответ 06.02.2014, 12:17:19
от jeka_808
Разъезжается таблица

Автор make_it

Ответов: 1
Просмотров: 1197
Последний ответ 28.05.2013, 18:26:10
от shketok