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

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
Добрый вечер/день.

С сайта joomshopping.pro был взять модуль Модуль Top Hits
Я его поковырял как мне надо, дополнил функции.

Но вот мне понадобилось получить топ хиты по определеному ID производителя.

Кто подскажет возможно ли такое сделать именно готовыми функциями шопинга?

как пример стандартного функционала получение хитов по категории
Код
 $cat_str = $params->get('catids', NULL); 

  if (is_array($cat_str)) {   
        $cat_arr = array();
        foreach($cat_str as $key=>$curr){
           if (intval($curr)) $cat_arr[$key] = intval($curr);
        } 
    } else {
        $cat_arr = array();
        if (intval($cat_str)) $cat_arr[] = intval($cat_str);
    }

$rows = $product->getTopRatingProducts($params->get('count_products', 4), $cat_arr);



Я пробовал сделать таким способом, по ай бренда  выбрал из всех товаров, N кол. товаров и закинул в массив новый. А там хотел отсортировать php сортировкой и вывести.
1. проблема после этого сайт начал очень долго грузится.
2.  Когда использовал я сортировку уже второго массива сайт падал 500 ошибкой. Может я не корректно ее применил ?
Код ниже
Спойлер
[свернуть]

Код
usort($мой_массив, function($a,$b){
    return ($a['hits']-$b['hits']);
});



-->
[свернуть]


P.S. Я соединил два модуля, хиты внедрил в Модуль Bestseller(модуль на том же сайте что и модуль хиты брал)
« Последнее редактирование: 26.10.2017, 17:55:27 от pavel2950 »
*

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
Сам разобрался, в components/com_jshopping/tables/product.php
в районе 990 строки я вставляю после  getTopHitsProducts функцию для получение, топ хитов по брендам

в функцию дабов. параметр для передачи $manuf_id,

а в SQL запрос добавил "AND prod.product_manufacturer_id = $manuf_id"



Код
function getTopHitsProductsManufacturer($count,  $array_categories = null, $manuf_id, $filters = array()){

        $jshopConfig = JSFactory::getConfig();

        $db = JFactory::getDBO();

        $adv_query = ""; $adv_from = ""; $adv_result = $this->getBuildQueryListProductDefaultResult();

        $this->getBuildQueryListProductSimpleList("tophits", $array_categories, $filters, $adv_query, $adv_from, $adv_result);

        $dispatcher = JDispatcher::getInstance();

        $dispatcher->trigger( 'onBeforeQueryGetProductList', array("top_hits_products", &$adv_result, &$adv_from, &$adv_query, &$order_query, &$filters));

        $query = "SELECT $adv_result FROM `#__jshopping_products` AS prod

                  INNER JOIN `#__jshopping_products_to_categories` AS pr_cat ON pr_cat.product_id = prod.product_id

                  LEFT JOIN `#__jshopping_categories` AS cat ON pr_cat.category_id = cat.category_id

                  $adv_from

                  WHERE prod.product_publish=1 AND cat.category_publish=1 ".$adv_query." AND prod.product_manufacturer_id = $manuf_id

                  GROUP BY prod.product_id

  ORDER BY prod.hits

  desc LIMIT ".$count;

        $db->setQuery($query);

        $products = $db->loadObjectList();

        $products = listProductUpdateData($products, 1);

        return $products;

    }

дальше строка вызова выглядела так

$brands = $product->getTopHitsProductsManufacturer($params->get('count_products', 7), $cat_arr,$manufacturer );


*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
как то вы сильно сложно подошли к вопросу :) ничего этого не нужно делать, тем более хакать ядро. все уже придумано до нас :) у метода getTopRatingProducts есть третий параметр $filters, массив, в который можно передать 'manufacturers' => array(ID производителя)

P.S. и качать что-либо с сайта joomshopping_pro тоже не нужно. мало того, что сайт никакого отношения к официальному сайту JoomShopping не имеет, так еще плюс к этому на него забили, и не обновляют давным давно.
« Последнее редактирование: 31.10.2017, 12:55:34 от dmitry_stas »
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
как то вы сильно сложно подошли к вопросу :) ничего этого не нужно делать, тем более хакать ядро. все уже придумано до нас :) у метода getTopRatingProducts есть третий параметр $filters, массив, в который можно передать 'manufacturers' => array(ID производителя)

P.S. и качать что-либо с сайта joomshopping_pro тоже не нужно. мало того, что сайт никакого отношения к официальному сайту JoomShopping не имеет, так еще плюс к этому на него забили, и не обновляют давным давно.

Большое спасибо, за подсказку. Как всегда выручили.


А можете все же подсказать, как правильно должен быть 3 параметр, а то я тык мык и не фига. Буду признателен и  + вам в репу кину)
« Последнее редактирование: 31.10.2017, 21:35:44 от pavel2950 »
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну так
массив, в который можно передать 'manufacturers' => array(ID производителя)

Код
$product->getTopRatingProducts($params->get('count_products', 4), $cat_arr, array('manufacturers' => array(ID производителя)));
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
array('manufacturers' => array(ID производителя))


Ооо большое спасибо, я пытался отпр. массив через переменую но не работало. А вот массив влепить сразу и нормас все. Вы гуру просто!!
*

dmitry_stas

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

Передать значение цены товара

Автор yurykom

Ответов: 16
Просмотров: 1063
Последний ответ 07.05.2019, 22:26:16
от dmitry_stas
Как передать select option в MySQL в форме заказа?

Автор Qverty2012

Ответов: 24
Просмотров: 2555
Последний ответ 17.06.2018, 16:03:42
от Qverty2012
передать параметры по ajax c JQ в php Полный вид товара

Автор pavel2950

Ответов: 3
Просмотров: 978
Последний ответ 18.08.2017, 14:40:16
от pavel2950
"Неверный параметр" при сбросе пароля

Автор PSN

Ответов: 6
Просмотров: 1225
Последний ответ 31.10.2016, 16:52:47
от kit2m2
Передать свою переменную из корзины в заказ

Автор Ragivort

Ответов: 8
Просмотров: 1175
Последний ответ 25.11.2015, 19:49:02
от dmitry_stas