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

PSN

  • Захожу иногда
  • 95
  • 0 / 0
Есть два дополнительных поля:



В БД это product_quantity_2 и product_quantity_3 соответственно.
В админке в карточке товара все выводится через
Цитировать
$row->product_quantity_2
$row->product_quantity_3
А в списке товаров ну никак не получается это количество вывести...
Там количество выводится через $row->qty.

Куда копать?

UPD: Копать сюда:

\administrator\components\com_jshopping\models\products.php - function getAllProducts - добавить свой запрос
« Последнее редактирование: 18.05.2016, 20:26:59 от PSN »
*

Taatshi

  • Гуру
  • 5258
  • 481 / 2
  • Верстаем и кодим. Обращайтесь ;)
Re: Вывод поля из БД в админке
« Ответ #1 : 17.05.2016, 07:46:44 »
Код: php
<?php
echo '<pre>';
print_r($row);
echo '</pre>';
?>

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

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Вывод поля из БД в админке
« Ответ #2 : 17.05.2016, 08:45:27 »
автоматически только в карточке товаров будет, в списке товаров нет. для списка товаров добавляйте поля в \components\com_jshopping\lib\jtableauto.php function getBuildQueryListProductDefaultResult
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

PSN

  • Захожу иногда
  • 95
  • 0 / 0
Re: Вывод поля из БД в админке
« Ответ #3 : 17.05.2016, 11:18:21 »
автоматически только в карточке товаров будет, в списке товаров нет. для списка товаров добавляйте поля в \components\com_jshopping\lib\jtableauto.php function getBuildQueryListProductDefaultResult

Тут речь про админку, а не сам сайт! Мне для удобства личного учета нужно, чтобы рядом со столбцом "Количество" отображалось еще два других количества (см. картинку выше)

Код: php
<?php
echo '<pre>';
print_r($row);
echo '</pre>';
?>

Если в переменной нет этих полей - делать запрос в базу данных за ними

Я понимаю так, что где-то рядом с qty не хватает дописать qty2 и qty3... Но где? Вчера долго все шерстил и пробовал, но ничего не вышло
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Вывод поля из БД в админке
« Ответ #4 : 17.05.2016, 16:12:53 »
Тут речь про админку, а не сам сайт!
сори, не обратил внимание. для админки - \administrator\components\com_jshopping\models\products.php function getAllProducts . добавляйте в запрос свои поля.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

PSN

  • Захожу иногда
  • 95
  • 0 / 0
Re: Вывод поля из БД в админке
« Ответ #5 : 18.05.2016, 20:26:03 »
сори, не обратил внимание. для админки - \administrator\components\com_jshopping\models\products.php function getAllProducts . добавляйте в запрос свои поля.

Благодарю за наводку - все получилось!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не сохраняется порядок товаров в админке

Автор heartlink

Ответов: 7
Просмотров: 1896
Последний ответ 08.10.2024, 10:24:02
от kit2m2
Ограничение Order number в админке?

Автор ИммоБокс

Ответов: 2
Просмотров: 1224
Последний ответ 13.03.2024, 11:26:33
от ИммоБокс
Ошибка при заполнении поля Улица/Номер дома. Как исправить ошибку?

Автор admi5575

Ответов: 9
Просмотров: 1630
Последний ответ 10.05.2023, 07:21:14
от admi5575
Дополнительные поля товаров Joomshoping

Автор Alex_gs

Ответов: 7
Просмотров: 1464
Последний ответ 07.10.2022, 07:57:41
от marksetter
В каких файлах строится вывод пунктов меню?

Автор Zelyonkin

Ответов: 9
Просмотров: 1039
Последний ответ 06.09.2021, 16:51:55
от Zelyonkin