Новости Joomla

👩‍💻 SW JProjects v.2.6.1 - компонент каталога расширений для веб-приложений.

👩‍💻 SW JProjects v.2.6.1 - компонент каталога расширений для веб-приложений.

Компонент позволяет сделать свой мини-Joomla Extensions Directory - каталог расширений для CMS (не только для Joomla) или файлов. Есть возможность скачивания по лицензионным ключам создания кастомных схем данных для сервера обновлений.

👩‍💻 v.2.6.1. Что нового?
- Правки наследования схем серверов обновлений. Улучшена логика наследования схем серверов обновлений для проектов компонент - категория - проект.
- Не стабильные релизы в сервере обновлений. Теперь в данные сервера обновлений попадают все версии (alpha, beta и т.д.), а не только stable.
- Косметические изменения. В шаблоне по умолчанию сделаны замены некоторых CSS-классов, уточнено присвоение атрибутов loading=lazy и fetchpriority.
- Рефакторинг и правки кода. Текущее обновление кодовой базы.
- Исправление ошибок.

👩‍💻 Больше спасибо за помощь в тестировании участникам нашего сообщества Александру Новикову (@pro_portal) и Александру Судьбинову (@alexrevo).

- Страница расширения
- GitHub расширения
- Joomla Extensions Directory

@joomlafeed

Событие Pizza, Bugs & Fun - 29-30 января 2026 года.

Событие Pizza, Bugs & Fun  - 29-30  января 2026 года.

Уже несколько лет в мире Joomla проводятся мероприятия "Pizza, Bugs & Fun" (#PBF), где каждый может посвятить несколько часов своего мозгового времени тому, чтобы наша любимая CMS стала ближе к идеалу.

Ссылки на видео и статьи из этого поста рассказывает об организационных вопросах, которые пригодятся для участия в PBF, а так же что и как делать.

В рамках события PBF все желающие могут собираться в общий онлайн чат, обсудить вопросы Joomla и приложить к их разрешению свою руку. Самый классный вариант, когда эта встреча происходит оффлайн: тогда организовывается пицца, напитки по вкусу и несколько часов совместного творчества.

Каждый помогает тем, что он умеет:

  • кто-то пишет недостающую документацию,
  • кто-то пишет код,
  • кто-то тестирует как исправлены ошибки или сделан новый функционал.

На сайте события есть карта, можно "захостить" свою локацию. Практически все движки в мире развиваются за счёт спонсирующих их компаний. Joomla одна из немногих, где развитие идёт только усилиями международного сообщества энтузиастов.

https://www.youtube.com/watch?v=a-FuVKXg_Uw 

На момент написания данного поста в репозитории Joomla 810 открытых Issue (как правило это баги) и 236 Pull request (PR, исправление багов и новый функционал). Все PR обязательно тестируются минимум двумя участниками сообщества, дабы в конечный код движка не проскочила ошибка.

Если каждый из участников только нашего сообщества сделает даже одно тестирование, то, боюсь, PR и Issue на всех не хватит 😀 И ничего не останется нашим коллегам из международных Joomla-чатов.

0 Пользователей и 1 Гость просматривают эту тему.
  • 2 Ответов
  • 1459 Просмотров
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Все привет.
Имеется на сайте поиск по сайту реализованный через связку RokAjaxSearch + plg_search_joomshopping-4.0.1 . Заметил недавно одну странность, точнее странным он казался давно, а тут обратил внимание на закономерность. Нету выбора поиск по названию и нельзя отсортировать по точному совпадению.
Есть товар ПироСтикер АСТ их много разновидностей. Если скопировать с названия "АСТ" и вбить в поиск, то выдает что хочешь, но не этот товар. Так как в названии его написали кириллицей. А вверху выдает популярное, либо сортировка по другим возможным вариантам где в любом слове описания встречается "аст". У меня это бронежилеты выдает, где в описании есть "чАСТичто".  А описания для пиростикеров  почти одинаковые, товар, если он похож, обычно копируется и  подправляется  и если взять этот же "АСТ" и скопировать с описания товар, его выдает в результатах. Как выяснилось в описании его написали латынью.
Я и раньше замечал что если скопировать название, то не всегда получал в выдаче этот товар а часто нету результата.  На сколько я понимаю за поиск по товарам отвечает именно плагин plg_search_joomshopping-4.0.1
Код
<?php
defined( '_JEXEC' ) or die( 'Restricted access' );
error_reporting(E_ALL & ~E_NOTICE);

jimport('joomla.plugin.plugin');

/*JPlugin::loadLanguage( 'plg_search_joomshopping' );*/

class plgSearchJoomshopping extends JPlugin {


    function onContentSearchAreas(){
        static $areas = array(
            'joomshopping' => 'JoomShopping'
        );
        return $areas;
    }


    function onContentSearch( $text, $phrase='', $ordering='', $areas=null )
    {
        require_once (JPATH_SITE.'/components/com_jshopping/lib/factory.php');
        require_once (JPATH_SITE.'/components/com_jshopping/lib/functions.php');      
        
        $db =  JFactory::getDBO();
        $user =  JFactory::getUser();
        $lang = JSFactory::getLang();
        
        if (is_array($areas)) {
            if (!array_intersect($areas, array_keys($this->onContentSearchAreas()))) {
                return array();
            }
        }
        
        $limit = $this->params->def( 'search_limit', 50 );

        $text = trim( $text );
        if ($text == '') {
            return array();
        }

        switch ( $ordering ) {
            case 'alpha':
                $order = "prod.`".$lang->get('name')."` ASC";
                break;          
            case 'newest':
                $order = "prod.`product_date_added` DESC";
                break;
            case 'oldest':
                $order = "prod.`product_date_added` ASC";
                break;    
            case 'popular':
                $order = "prod.`hits` DESC";
                break;                                    
            case 'category':
                $order = 'cat.`'.$lang->get('name').'` ASC, prod.`'.$lang->get('name').'` ASC';
                break;
            default:
                $order = 'prod.product_id DESC';
        }
        
        switch ($phrase) {
            case 'exact':
                $text        = $db->Quote( '%'.$db->escape( $text, true ).'%', false );
                $wheres2     = array();
                $wheres2[]     = "prod.`".$lang->get('name')."` LIKE ".$text;
                $wheres2[]     = "prod.`".$lang->get('short_description')."` LIKE ".$text;
                $wheres2[]     = "prod.`".$lang->get('description')."` LIKE ".$text;
                $wheres2[]     = "prod.product_ean LIKE ".$text;
                $where         = '(' . implode( ') OR (', $wheres2 ). ')';
            break;

            case 'all':
            case 'any':
            default:
                $words = explode( ' ', $text );
                $wheres = array();
                foreach ($words as $word) {
                    $word        = $db->Quote( '%'.$db->escape( $word, true ).'%', false );
                    
                    $wheres2     = array();
                    $wheres2[]     = "prod.`".$lang->get('name')."` LIKE ".$word;
                    $wheres2[]     = "prod.`".$lang->get('short_description')."` LIKE ".$word;
                    $wheres2[]     = "prod.`".$lang->get('description')."` LIKE ".$word;
                    $wheres2[]     = "prod.product_ean LIKE ".$word;
                    $wheres[]     = implode( ' OR ', $wheres2 );
                }
                $where = '(' . implode( ($phrase == 'all' ? ') AND (' : ') OR ('), $wheres ). ')';
            break;
        }
        
        $query = "SELECT prod.product_id AS slug, pr_cat.category_id AS catslug, prod.`".$lang->get('name')."` as title,
                  CONCAT(prod.`".$lang->get('short_description')."`,' ',prod.`".$lang->get('description')."`) as text,
                  '2' AS browsernav,
                  prod.product_date_added AS created,
                  cat.`".$lang->get('name')."` AS section
                  FROM `#__jshopping_products` AS prod
                  LEFT 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                  
                  WHERE ($where) AND prod.product_publish = '1' AND cat.category_publish='1'                
                  GROUP BY prod.product_id
                  ORDER BY $order
                  ";    
        
        $db->setQuery( $query, 0, $limit );
        $rows = $db->loadObjectList();
        
        if ($rows){
            foreach($rows as $key => $row) {
                $rows[$key]->href = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id='.$row->catslug.'&product_id='.$row->slug, 1);
            }
        }
        return $rows;
    }
}
?>
Вопрос. Кто то может еще обращал внимание на такое и может кто-то знает как это можно исправить? Нужно вообще что бы приоритетным был поиск по названию.
« Последнее редактирование: 14.07.2017, 12:06:35 от misteri27 »
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Народ, помогите сделать поиск приоритетным по названию. Ну или выдачу первым то что совпало в названии целиком слово. Если нужна оплата то готов рассмотреть.
*

Edward_m

  • Захожу иногда
  • 146
  • 0 / 0
Народ, помогите сделать поиск приоритетным по названию. Ну или выдачу первым то что совпало в названии целиком слово. Если нужна оплата то готов рассмотреть.
Напиши в коммерческий отдел. там тебе быстро ответят. если ты хочешь за кэш
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

WT On fly image handler изображения товара JoomShopping в webp на лету

Автор sergeytolkachyov

Ответов: 13
Просмотров: 4822
Последний ответ 29.01.2025, 20:38:38
от sergeytolkachyov
Видео с Youtube вместо картинки на карточке товара

Автор ksena

Ответов: 35
Просмотров: 10825
Последний ответ 08.10.2024, 04:26:36
от kit2m2
Подтвердите повторную отправку формы - JoomShopping поиск

Автор Kokshetau

Ответов: 11
Просмотров: 6177
Последний ответ 07.08.2024, 15:07:05
от mag_num83
Условие для кол-ва товара больше нуля

Автор kik84

Ответов: 3
Просмотров: 1491
Последний ответ 16.02.2024, 13:33:24
от kit2m2
Разные ссылки и названия на один товар

Автор gooodwin67

Ответов: 2
Просмотров: 1277
Последний ответ 04.11.2023, 12:34:19
от nevigen