Новости Joomla

Модификация WT JShopping products anywhere - Uikit макетИтак, дано: музыкальный журнал, в котором...

Модификация WT JShopping products anywhere - Uikit макетИтак, дано: музыкальный журнал, в котором...

Модификация WT JShopping products anywhere - Uikit макетИтак, дано: музыкальный журнал, в котором представлены новости, интервью, рецензии и есть небольшой магазин на JoomShopping. Возникла необходимость внутри Joomla статей вставлять упоминание релиза и кнопочку «добавить в корзину». Я взял плагин WT JShopping products anywhere Сергея Толкачева (@webtolkru). Плагин отображает название товара и ссылку. При помощи напильника, ИИ и навыков вёрстки появился Uikit макет для шаблонов на базе Yootheme Pro.Учитываается мобильная версия - телефоны и ipad.Кнопка добавления в корзину работает по Ajax и появляется всплывающее окно (Notification Bar от Uikit) с информацией.Пока это базовый вариант, требующий доведения до лоска, однако он уже работает и его можно применять на проектах.Взять макет можно здесь.А плагин вставки товаров в материалы можно забрать здесь.Приветствуется доведение до ума и оформление в виде PR.

WT Content Image Gallery v.1.2.3 - плагин галереи изображений для Joomla

WT Content Image Gallery v.1.2.3 - плагин галереи изображений для Joomla

👩‍💻 WT Content Image Gallery v.1.2.3 - плагин галереи изображений для Joomla.Пакет плагинов галереи изображений и видео для вставки в материалы и модули Joomla, а так же везде, где работают плагины группы content. Поддержка собственных макетов вывода для галерей. Смешанные фото+видео галереи. Плагин создан как замена Simple Image Gallery и поддерживает синтаксис {gallery}{/gallery}.👩‍💻 v.1.2.3. Что нового?- Обработка вступительного и полного текста для материалов Joomla. Добавлена обработка шорткодов в полном и вступительном текстах материалов Joomla.- Системные требования. Повышены минимальные требования до Joomla 5 и PHP 8.1.- Мелкие правки. Исправлена ошибка работы макета по умолчанию в плагине контента.- Joomla 6. Пакет плагинов успешно протестирован на Joomla 6.Страница расширения.GitHub расширенияJoomla Extensions Directory@joomlafeed#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 Гость просматривают эту тему.
  • 10 Ответов
  • 1834 Просмотров
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Добрый день!
Подскажите пожалуйста где в JoomShopping шаблоны типов меню? Хочу сделать дополнительные поля для типа "Список товаров": ID характеристики и ID опции.
Сейчас там можно выбрать только: Категория ID, Производитель ID, Метка ID, Продавец ID. То есть хочется получить список товаров по определёной опции одной из характеристик. Например: цвет - синий. Выведет все синие товары.
*

dmitry_stas

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

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Почему не позволяет? Там же где то есть запрос в базу на ID категории. Я вот и спрашиваю, как найти где создаётся этот запрос, что бы добавить свой. Просто в файл php впишу аналогично.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Почему не позволяет?
ну как почему... потому что не позволяет :) нет такого механизма в базе.

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

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Извините, я видимо неправильно вопрос поставил, заработался.
Имелось в виду в меню создаётся запрос/ссылка "index.php?option=com_jshopping&view=products&category_id=1&manufacturer_id=1"
Я и хочу узнать куда идёт этот запрос, где происходит обработка этих опций?
А запрос к базе это просто банальный запрос к базе с помощью API Joomla, как описано в документации. Поэтому я не очень понимаю "потому что не позволяет Azn нет такого механизма в базе." Видимо Вы имеете в виду какую то другую вещь, потому что SELECT * FROM table_name; я могу сделать где угодно и как угодно.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
угу, другую. база - это я имел в виду не базу MySQL, а базовые возможности JoomShopping. нет возможности по-умолчанию создать такой пункт меню, нужны доработки, вот что я имел в виду. а если вы конечно сами формируете его, руками или как то еще, то это совсем другой вопрос. по такой ссылке, как вы указали, запрос формируется в \components\com_jshopping\tables\product.php function getAllProducts
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Благодарю! Именно то что нужно.
*

dmitry_stas

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

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
*

dmitry_stas

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

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Как обещал выкладываю, что пока наковырял.
В файл components\com_jshopping\views\products\tmpl\default.xml добавил строку поля, аналогично другим строкам:
Код
<field name="option_id" type="text" default="" label="option_id" description="option_id" />
В файл components\com_jshopping\tables\product.php вписал следующее:
Код
function getAllProducts($filters, $order = null, $orderby = null, $limitstart = 0, $limit = 0){

        $jshopConfig = JSFactory::getConfig();
        $lang = JSFactory::getLang();
        $adv_query = ""; $adv_from = ""; $adv_result = $this->getBuildQueryListProductDefaultResult();

        $extraField = JRequest::getVar('option_id');

//Пока что костыль для mod_jshopping_filters_extended, в дальнейшем надо нормально сделать
        if (NULL !== $extraField) {
            $filters2 = $filters;
            $filters2['extra_fields'] = array();
        } else {
            $filters2 = $filters;
        }
       $this->getBuildQueryListProduct("products", "list", $filters2, $adv_query, $adv_from, $adv_result);
//Конец костыля

        $order_query = $this->getBuildQueryOrderListProduct($order, $orderby, $adv_from);
 
        $dispatcher = JDispatcher::getInstance();

//Ещё костылик $filters2
        $dispatcher->trigger( 'onBeforeQueryGetProductList', array("all_products", &$adv_result, &$adv_from, &$adv_query, &$order_query, &$filters2) );


//Сортировка по option_id
        if (NULL !== $extraField) {
$query='SHOW COLUMNS FROM `#__jshopping_products`';
$this->_db->setQuery($query);
$fields_in_table=$this->_db->loadObjectList();
$field_sql_string='';
foreach($fields_in_table as $myobj){
$field_sql_string.=(preg_match("/extra_field_[0-9]/", $myobj->Field)?'prod.'.$myobj->Field.',':'');
}
            $adv_query .= ' AND ' . intval($extraField) . ' IN ('.substr($field_sql_string,0,-1).')';
        }

        $query = "SELECT $adv_result FROM `#__jshopping_products` AS prod
                  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
                  $adv_from
                  WHERE prod.product_publish=1 AND cat.category_publish=1 ".$adv_query."
                  GROUP BY prod.product_id ".$order_query;

if ($limit){
            $this->_db->setQuery($query, $limitstart, $limit);
        }else{
            $this->_db->setQuery($query);
        }

        $products = $this->_db->loadObjectList();
        $products = listProductUpdateData($products, 1);
        return $products;
    }

Пока так. Сейчас сражаюсь с фильтром и пагинацией.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор sergeytolkachyov

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

Автор sergeytolkachyov

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

Автор goga_pgasovav

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

Автор sergeytolkachyov

Ответов: 0
Просмотров: 1541
Последний ответ 24.12.2024, 14:50:42
от sergeytolkachyov
Сортировка товаров в админке

Автор Emotion

Ответов: 26
Просмотров: 6722
Последний ответ 15.08.2024, 08:00:20
от kit2m2