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

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
Кто подскажет.
Как можно привязать категории к производителям.
Чтобы потом при выборе производителя выводить список категорий этого производителя.

Как вариант может в таблицу категорий добавить поле и в админке прописать выборку из производителей.
Потом уже играть выводом.
Кто подскажет как это лучше реализовать.

Если есть платная реализация, дайте ссылку.


Спасибо
« Последнее редактирование: 19.01.2016, 18:28:51 от octopus »
*

dmitry_stas

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

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
насколько понял.
необходимо сделать запрос на выборку товара производителя и вытянуть категории из них?
*

dmitry_stas

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

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
именно так. навскидку - одним запросом можно сделать через LEFT JOIN

спасибо.
немного кривовато, но получилось.

ещё вопрос про ссылки. категории вывожу, а как правильные ссылки на них прописать.
у меня привязка к категориям через главное меню
*

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
спасибо.
немного кривовато, но получилось.

ещё вопрос про ссылки. категории вывожу, а как правильные ссылки на них прописать.
у меня привязка к категориям через главное меню


разобрался.
вытащил из шаблона
спасибо.
+
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
SEFLink('index.php?option=com_jshopping&controller=category&task=view&category_id='.$category_id, 1)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
прошу помощи
что-то ни как не получается вывести по человечески

на странице производителя хочу вывести категории, в которых он есть.
через phpadm запросы формирую, но в страницу не могу ни как запхнуть.

спасибо.
*

dmitry_stas

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

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
делаю выборку для пробы через phpadmin
делаю двумя селектами. с left join не очень знаком пока (в процессе активного обучения mysql)
дело не в том как получаю данные, а как их вставить в шаблон
в каталоге manufacturer/ в файл products.php надо его вставить.
но как это сделать не могу что-то понять
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Привязка категорий к производителю
« Ответ #10 : 31.01.2016, 12:49:21 »
дело не в том как получаю данные, а как их вставить в шаблон
вставить - это Ctrl+V. или правой кнопкой мыши - Вставить.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
Re: Привязка категорий к производителю
« Ответ #11 : 31.01.2016, 12:56:26 »
вставить - это Ctrl+V. или правой кнопкой мыши - Вставить.
это точно )))) спасибо что напомнили

может вопрос уже не в этой теме, но
как правильно вставить запрос к базе
создаю функцию в шаблоне

$db = JFactory::getDBO();
$query = "запрос"
$db->setQuery($query);
... и что-то дальше затык у меня.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Привязка категорий к производителю
« Ответ #12 : 31.01.2016, 13:00:00 »
зависит от того, какие данные ожидаются в ответе на запрос. например
Код
$db->setQuery($query);
$rows = $db->loadObjectList();
print_r($rows);
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
Re: Привязка категорий к производителю
« Ответ #13 : 31.01.2016, 13:12:24 »
зависит от того, какие данные ожидаются в ответе на запрос. например
Код
$db->setQuery($query);
$rows = $db->loadObjectList();
print_r($rows);

нужно получить массив.
дальше выведу через $массив[id]
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Привязка категорий к производителю
« Ответ #14 : 31.01.2016, 13:15:41 »
массив чего? массив строк? или массив столбцов?
loadObjectList - тоже массив. только массив объектов.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
Re: Привязка категорий к производителю
« Ответ #15 : 31.01.2016, 13:27:46 »
массив строк.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Привязка категорий к производителю
« Ответ #16 : 31.01.2016, 13:28:14 »
$db->loadColumn()
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

octopus

  • Захожу иногда
  • 169
  • 8 / 0
  • Во всём можно разобраться... Если захотеть.
Re: Привязка категорий к производителю
« Ответ #17 : 31.01.2016, 13:37:42 »
спасибо большое
разобрался
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[JoomShopping 5] вывод товаров из дочерних категорий

Автор v42bis

Ответов: 15
Просмотров: 2669
Последний ответ 14.06.2024, 11:43:28
от denistischenko
Несколько категорий на одной странице

Автор geral

Ответов: 4
Просмотров: 915
Последний ответ 21.04.2023, 16:15:49
от geral
Скидки для разных групп и разных категорий

Автор misteri27

Ответов: 4
Просмотров: 720
Последний ответ 11.06.2021, 13:50:32
от kit2m2
Обнулить ID товаров и категорий в JoomShopping

Автор Rebarun

Ответов: 4
Просмотров: 753
Последний ответ 01.07.2020, 21:57:29
от Rebarun
Привязка нескольких категорий к одному пункту меню)

Автор gorbunov.y.a

Ответов: 13
Просмотров: 1994
Последний ответ 29.05.2020, 08:08:49
от nevigen