Новости 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 Ответов
  • 1567 Просмотров
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Как вывести дополнительную цену из БД в списке товаров в админке.
Добавил код в файл списка товаров в админке
Код
<td>
  <?php echo formatprice($row->product_price, sprintCurrency($row->currency_id));?>
</td>
<td>
  <?php echo formatprice($row->product_myprice, sprintCurrency($row->currency_id));?>
</td>
Добавил в БД строку product_myprice ниже цены товара и заполнил значениями.
Но в админке ничего не выводится.
Подскажите, пожалуйста, какие еще файлы поправить чтобы вывод моей цены заработал.
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
\administrator\components\com_jshopping\models\products.php
Функция getAllProducts
Нужно добавить в SELECT Ваше поле (в двух запросах)
pr.product_myprice
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Вставил в эту функцию, после pr.product_price свою цену pr.product_myprice, в 2-х запросах.
Не сработало, список товаров вообще не выводится. В структуре БД product_myprice существует после product_price.
Где еще нужно добавить?
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Переменная product_price_disc

Сначала вывел тут
administrator/components/com_jshopping/views/product_list/tmpl/default.php
Код
<?php echo formatprice($row->product_price_disc, sprintCurrency($row->currency_id));?>

Потом сделал изменения тут
administrator/components/com_jshopping/models/products.php
Код
if ($category_id) {
            $query = "SELECT pr.product_id, pr.product_publish, pr_cat.product_ordering, pr.`".$lang->get('name')."` as name, pr.`".$lang->get('short_description')."` as short_description, man.`".$lang->get('name')."` as man_name, pr.product_ean as ean, pr.product_quantity as qty, pr.product_thumb_image as image, pr.product_price, pr.product_price_disc, pr.currency_id, pr.hits, pr.unlimited, pr.product_date_added, pr.label_id $query_filed FROM `#__jshopping_products` AS pr
                      LEFT JOIN `#__jshopping_products_to_categories` AS pr_cat USING (product_id)
                      LEFT JOIN `#__jshopping_manufacturers` AS man ON pr.product_manufacturer_id=man.manufacturer_id
                      $query_join
                      WHERE pr.parent_id=0 ".$where." ".$this->_allProductsOrder($order, $orderDir, $category_id)." ".$limit;
        }else{
            $mysqlversion = getMysqlVersion();
            if ($mysqlversion < "4.1.0"){
                $spec_where = "cat.`".$lang->get('name')."` AS namescats";
            }else{
                $spec_where = "GROUP_CONCAT(cat.`".$lang->get('name')."` SEPARATOR '<br>') AS namescats";
            }
           
            $query = "SELECT pr.product_id, pr.product_publish, pr.`".$lang->get('name')."` as name, pr.`".$lang->get('short_description')."` as short_description, man.`".$lang->get('name')."` as man_name, ".$spec_where.", pr.product_ean as ean, pr.product_quantity as qty, pr.product_thumb_image as image, pr.product_price, pr.product_price_disc, pr.currency_id, pr.hits, pr.unlimited, pr.product_date_added, pr.label_id $query_filed FROM `#__jshopping_products` AS pr
                      LEFT JOIN `#__jshopping_products_to_categories` AS pr_cat USING (product_id)
                      LEFT JOIN `#__jshopping_categories` AS cat ON pr_cat.category_id=cat.category_id
                      LEFT JOIN `#__jshopping_manufacturers` AS man ON pr.product_manufacturer_id=man.manufacturer_id
                      $query_join
                      WHERE pr.parent_id=0 ".$where." GROUP BY pr.product_id ".$this->_allProductsOrder($order, $orderDir)." ".$limit;
        }
После того как добавил в селект переменную список товаров вообще не выводится.
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Огромное спасибо, все получилось!
Вопрос закрыт, невнимателен в коде сайта.
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Огромное спасибо, все получилось!
Вопрос закрыт, невнимателен в коде сайта.
В карточке товара для вывода моей цены сработал код
Код
formatprice($this->product->product_price_disc)
А как в категории или в другом месте вывести мою цену? Код ниже не работает, ничего не выводит.
components/com_jshopping/templates/default/list_products/product.php
Код
<?php print formatprice($product->product_price_disc);?>
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
\components\com_jshopping\lib\jtableauto.php function getBuildQueryListProductDefaultResult
А что относительно корзины?
<?php print formatprice($prod['price_disc'])?> // в оригинале было ['price']
« Последнее редактирование: 21.10.2015, 10:49:02 от tomas_morgam »
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
с корзины надо начинать было. тогда бы вам сразу сказали, что там далеко не одна строка. вывести цену - это одно. а учитывать ее при покупке - совсем другое. ковыряйте модель cart
Спасибо, это также получилось. И последнее, правка емейл, где смотреть? Открыл модель checkout.php - не понятно где именно вытягивается цена и как "подсунуть" свою переменную.
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
какой email?
Шаблон письма-заказа, который отсылается на почту.
/components/com_jshopping/templates/default/checkout/orderemail.php
Код
<?php print formatprice($prod->product_price_disc*$prod->product_quantity, $order->currency_code); ?>
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну так а вы в заказ уже сохранили свою цену?

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Да, цену подключил в форме заказа просто сменив "price" на "price_disc".
Код
<?php print formatprice(($prod['price_disc'])*$prod['quantity']);?>
С формирование емейл так не выходит.

Так я и не могу найти где выводится стандатрая цена, чтобы изменить на новую.
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Как вывести в списке товара возле названия список категорий, к которым подключен товар (товар в 2-3 категориях).
Желательно перед этим кодом
Код
<?php if (!$manufacturer_id){?>        
   <td>
      <?php echo $row->man_name;?>
   </td>
   <?php }?>
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
Код: php
<?php if (!$category_id){?>
   <td>
      <?php echo $row->namescats;?>
   </td>
   <?php }?>
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

WT JoomShopping Favorite - кнопки избранного в категории товаров и карточке тов

Автор sergeytolkachyov

Ответов: 25
Просмотров: 35716
Последний ответ 23.09.2025, 11:22:23
от Alex_gs
Модуль карусели товаров JoomShopping на Swiper.js для Joomla

Автор sergeytolkachyov

Ответов: 2
Просмотров: 2049
Последний ответ 04.07.2025, 10:30:36
от sergeytolkachyov
[Решено] Сбросить счётчик ID товаров JoomShopping

Автор goga_pgasovav

Ответов: 3
Просмотров: 1359
Последний ответ 13.02.2025, 00:11:20
от goga_pgasovav
Плагин обновления цен и остатков товаров JoomShopping из CSV

Автор sergeytolkachyov

Ответов: 0
Просмотров: 1536
Последний ответ 24.12.2024, 14:50:42
от sergeytolkachyov
JoomShopping как вывести фильтр в наличии

Автор thevaca

Ответов: 4
Просмотров: 1645
Последний ответ 15.08.2024, 17:41:20
от thevaca