Новости Joomla

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

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
а то выводит всё что и ещё найдёт в описании. очень, мягко говоря, неудобно. !

JS Version 3.17.1
Joomla! 2.5.20
« Последнее редактирование: 04.09.2014, 14:40:15 от permstyle »
*

nevigen

  • Moderator
  • 10436
  • 863 / 25
  • http://n*****n.com
в плагине (не модуле, а именно плагине поиска ЖШ) поиска уберите все лишнее на ваш взгляд.
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
*

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
прошу прощения: именно плагина поиска ЖШ у меня нет.
есть сам компонент и модуль Jshopping Search
*

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
установил plg_search_joomshopping-4.0.0
код ниже. можете подсказать, что убрать?
Код
<?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;
    }
}
?>
*

nevigen

  • Moderator
  • 10436
  • 863 / 25
  • http://n*****n.com
ну модуль скорее всего прямо через контролер отрабатывается.
попробуйте поискать там.

я обычно не использую модуль.
обычного Joomla модуля поиска более чем достаточно, при установленном плагине

все что описание, переводится как description :)
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
*

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
попробую сейчас почистить код плагина. отпишусь скоро.
*

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
почистил
Код
<?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.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.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 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;
    }
}
?>

попробовал. эффект тот же. такое чувство, словно он к плагину и не пробует обращаться
*

nevigen

  • Moderator
  • 10436
  • 863 / 25
  • http://n*****n.com
модуль к плагину не обращается.
обычный модуль поиска Joomla использует плагин.

Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
*

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
попробую тогда components/com_jshopping/controllers/search.php подправить от description
*

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
nevigen, большое спасибо.

можно ещё последний вопрос:
например ищем СТОЛ.. и он выводит СТОЛ, СТОЛещница, для СТОЛа..
как сделать чтобы выводил отдельно стоящее слово?
Код
 $where_search = "";
        if ($search_type=="exact"){
            $word = addcslashes($db->escape($search), "_%");
            $where_search = "LOWER(prod.`".$lang->get('name')."`) LIKE '%" . $word . "%' ";
        }else{       
            $words = explode(" ", $search);
            $search_word = array();
            foreach($words as $word){
                $word = addcslashes($db->escape($word), "_%");
                $search_word[] = "(LOWER(prod.`".$lang->get('name')."`) LIKE '%" . $word . "%' )";
            }
            if ($search_type=="any"){
                $where_search = implode(" OR ", $search_word);
            }else{
                $where_search = implode(" AND ", $search_word);
            }
        }
        if ($where_search) $adv_query .= " AND ($where_search)";
*

dmitry_stas

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

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
к сожалению, при таких правках сообщает, что ничего не найдено
Код
$where_search = "";
        if ($search_type=="exact"){
            $word = addcslashes($db->escape($search), "_%");
            $where_search = "LOWER(prod.`".$lang->get('name')."`) = '" . $word . "' ";
        }else{       
            $words = explode(" ", $search);
            $search_word = array();
            foreach($words as $word){
                $word = addcslashes($db->escape($word), "_%");
                $search_word[] = "(LOWER(prod.`".$lang->get('name')."`) = '" . $word . "' )";
            }
            if ($search_type=="any"){
                $where_search = implode(" OR ", $search_word);
            }else{
                $where_search = implode(" AND ", $search_word);
            }
        }
        if ($where_search) $adv_query .= " AND ($where_search)";
*

dmitry_stas

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

permstyle

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

permstyle

  • Захожу иногда
  • 148
  • 2 / 0
большое спасибо, dmitry_stas
всё решил.
Код
RLIKE '[[:<:]]" . $word . "[[:>:]]' )"
*

MadKitty

  • Захожу иногда
  • 62
  • 1 / 0
Подскажите, пожалуйста, а как в плагине поиска JoomShopping сделать поиск по всей надписи, а не по каждому слову?
*

dmitry_stas

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

MadKitty

  • Захожу иногда
  • 62
  • 1 / 0
обычно это настройка модуля
Стоит модуль аякс-поиска, в самом модуле ищет как надо, а при нажатии на Enter или кнопку показывает товары по каждому слову, а не по всей фразе целиком, как в модуле (
*

MichailPickStyle

  • Захожу иногда
  • 65
  • 2 / 0
permstyle, dmitry_stas спасибо!
Код
RLIKE '([[:<:]]" . $word . "[[:>:]]' )"
Добавил только "("(обернул регулярку), а то была ошибка синтаксиса)
*

MichailPickStyle

  • Захожу иногда
  • 65
  • 2 / 0
Всем привет!
Снова вопрос по этой теме)
Сделал изменения  приведенные выше, и только сейчас заметил, что поиск теперь не находит совпадений, если введенное название начинается с заглавной буквы.
Например:
есть товар: ' диван "Дельта" '
в поиске вводим ' дельта ' - находит, а если: ' Дельта ' - не находит.)
Практически наобум влепил в
Код
private function buildAdvQuery($filters, $order = null, $orderby = null)
строку
Код
$filters['search'] = mb_strtolower($filters['search']);
Теперь нормально отрабатывает.
Не подскажите более грамотный вариант исправления ситуации?
*

shop.letniysad.pro

  • Новичок
  • 4
  • 0 / 0
Умные люди, подскажите, пожалуйста. Пользуюсь на сайте модулем поиска JoomShopping Search.  Третий день ищу, где откорректировать запрос, чтобы поиск шел только по названию товара, а не по описанию.  *ОХ-Х-Х* *ОХ-Х-Х* Все форумы перекурил. Такое ощущение, что все пользуются плагином и штатным поиском Joomla.
*

kit2m2

  • Живу я здесь
  • 3269
  • 268 / 0
  • Беру сайты на полное сопровождение
где откорректировать запрос, чтобы поиск шел только по названию товара,
Создайте в папке components/com_jshopping/lib/ - Файл - user_config.php со следующим кодом:

Код
<?php
defined('_JEXEC') or die();

$config->product_search_fields = array(
    'prod.ml:name',/* поиск по названию товара */
    'prod.product_ean'/* поиск по коду товара */
);
Расширения для JoomShopping | Расширения на заказ | Сайты и магазины под ключ: Дизайн, Верстка, Программирование, СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ и JoomShopping 5+
*

gartes

  • Завсегдатай
  • 1859
  • 142 / 6
  • Е = mс²
Создайте в папке components/com_jshopping/lib/ - Файл - user_config.php со следующим кодом:
Тут просто нельзя - не отметить того - на сколько правильное решение
*

shop.letniysad.pro

  • Новичок
  • 4
  • 0 / 0
Создайте в папке components/com_jshopping/lib/ - Файл - user_config.php со следующим кодом:

Помогло! Спасибо большое! Все так просто, оказывается!! Вы сделали этот день!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Условие для кол-ва товара больше нуля

Автор kik84

Ответов: 3
Просмотров: 328
Последний ответ 16.02.2024, 13:33:24
от kit2m2
Как отобразить строку поиска настраиваемого размера Joomla+JoomShopping?

Автор zantal

Ответов: 1
Просмотров: 591
Последний ответ 19.10.2023, 18:29:32
от kit2m2
WT On fly image handler изображения товара JoomShopping в webp на лету

Автор sergeytolkachyov

Ответов: 9
Просмотров: 1533
Последний ответ 17.10.2023, 12:40:19
от sergeytolkachyov
Убрать модуль в карточке товара JoomShopping

Автор alexkraym

Ответов: 35
Просмотров: 4444
Последний ответ 21.08.2023, 07:17:53
от delchev
Отображения описании категории только на первой странице

Автор graf

Ответов: 5
Просмотров: 1181
Последний ответ 04.05.2023, 18:52:08
от kit2m2