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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Добрый день. Прошу Вашей помощи.
Joomla 3.6.3
JoomShopping 4.14.3
При заказе приходит письмо (в прикрепленном файле), в котором все поля пустые. Товары добавляются из всех заказов, а не только из последнего. Итоговая сумма 0 руб.
Такое происходит и на своем шаблоне JS, и на стандартном.
В коде orderemail.php ничего не меняла.
В чем может быть проблема?
*

dmitry_stas

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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
а где меняли?
В своем шаблоне меняла вывод категорий, списка товаров.
Но и со стандартным шаблоном неправильно формируется.
*

dmitry_stas

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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
кроме шаблона - что меняли?
Сайт заразили вирусами, он был восстановлен. Файлы Joomla не менялись. ЖШ установлен чистый, импортированы строки бд.
*

dmitry_stas

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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
а вы уверены, что структура БД не нарушилась?
Уверена, т.к. устанавливалась чистая Joomla, и импортировались строки бд нужные.
*

kit2m2

  • Живу я здесь
  • 3366
  • 276 / 0
  • Беру сайты на полное сопровождение
Этот аддон установите и проверьте базу данных самого JoomShopping.

У Вас скорее всего нарушена/неправильная структура таблиц именно JoomShopping. Когда копировали из базы в базу версии Joomla и JoomShopping были идентичные или отличались?
Расширения для JoomShopping | Ссылка на Телеграм-канал | Сайты и магазины под ключ: Дизайн, Верстка, Программирование (расширения на заказ), СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ (5+) и JoomShopping 5+
*

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Этот аддон установите и проверьте базу данных самого JoomShopping.

У Вас скорее всего нарушена/неправильная структура таблиц именно JoomShopping. Когда копировали из базы в базу версии Joomla и JoomShopping были идентичные или отличались?
Идентичные, сейчас попробую.
*

dmitry_stas

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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Проверка бд  ЖШ показала:
categories   category_ordertype      Нет колонки - category_ordertype
Как исправить?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
там есть кнопка Исправить, но для вашей проблемы это не критично, проблема у вас в чем то другом. еще раз - уверены ли вы, что в импортируемых строках логика не нарушена? может их вирус покрошил?

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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
БД поправила, проблем в ней больше нет.
Стала по вашему совету проверять номера заказов. И пробные удалила. На что выдалось сообщение:
Заказ ID 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 был удален

Заказу в БД присваивается 0 ID, видимо из-за этого и возникают ошибки.
« Последнее редактирование: 20.10.2016, 09:55:05 от BelMary »
*

dmitry_stas

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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
столбцу order_id в таблице `#__jshopping_orders` задан AUTO_INCREMENT?
Нет.
*

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Спасибо вам огромное, все исправила!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Ошибка при правке данных клиента и попытке отправить письмо из заказа

Автор ecolora

Ответов: 40
Просмотров: 2689
Последний ответ 17.09.2022, 20:06:26
от marksetter
Как в JoomShopping редактировать письмо отправляемое автоматически?

Автор Ne01eX

Ответов: 47
Просмотров: 9736
Последний ответ 12.09.2022, 11:46:36
от kit2m2
Загрузка макета при заказе

Автор misteri27

Ответов: 4
Просмотров: 850
Последний ответ 14.07.2022, 11:15:26
от nevigen
Не посчиталась стоимость товара в заказе, в админке есть

Автор Dolphin4ik_1

Ответов: 1
Просмотров: 550
Последний ответ 28.05.2022, 15:20:28
от victorantoniak
Изменить письмо-заказ

Автор mesmer

Ответов: 14
Просмотров: 6066
Последний ответ 22.07.2021, 17:12:30
от ureel