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

orsy

  • Давно я тут
  • 393
  • 21
  • Web-Factor Ukraine
Столкнулся недавно с тем что порядок отображения полей поиска в модуле mod_adsmanager_search совершенно не зависит от того в каком порядке эти самые поля указаны в его настройках.

В этом модуле есть 5 пронумерованных полей, в которые вставляются имена характеристик объявления.
Логично было ожидать что в модуле поля будут отображаться в том же порядке в котором указаны в настройках модуля, но...

Но дело в том что поля эти в модуле выводятся в том порядке, который им задан в компоненте AdsManager, не помню точно для какой части, может для формы подачи объявления или страницы отображения объявления.

Для того чтобы поля поиска в модуле отображались в том порядке, в котором мы указали их в настройках модуля, необходимо:

1. Открываем файл /administrator/components/com_adsmanager/models/field.php
2. Ищем в этом файле функцию getFieldsByName содержимое оной приведено ниже

Код
     function getFieldsByName($listfields,$usergroups=true,$mode='read') {
$query = "SELECT f.* FROM #__adsmanager_fields AS f ".
"WHERE f.name IN ($listfields) AND f.published = 1 ORDER by f.ordering" ;
$this->_db->setQuery( $query);
$searchfields = $this->_db->loadObjectList("name");

foreach($searchfields as $key => $field) {
$searchfields[$key]->options = json_decode($field->options);
}

if($usergroups) {
require_once(JPATH_ROOT.'/components/com_adsmanager/lib/tpermissions.php');
$searchfields = TPermissions::getAuthorisedFields($searchfields, $mode);
}

return $searchfields;
    }

3. Копипастим эту функцию вместе с содержимым ниже и меняем ее название например на getFieldsByPosModule
4. Заменяем вот эту часть кода:

Код
$query = "SELECT f.* FROM #__adsmanager_fields AS f ".
"WHERE f.name IN ($listfields) AND f.published = 1 ORDER by f.ordering" ;
$this->_db->setQuery( $query);
$searchfields = $this->_db->loadObjectList("name");

на этот код

Код
$listfieldsformod = str_replace ( "'" , "" , $listfields );					 
$query = "SELECT f.* FROM #__adsmanager_fields AS f "."WHERE f.name IN ($listfields) AND f.published = 1 order by find_in_set(f.name, '$listfieldsformod')";
$this->_db->setQuery( $query);
$searchfields = $this->_db->loadObjectList();

5. открываем файл /modules/mod_adsmanager_search/mod_adsmanager_search.php

6. Находим место где используется функция getFieldsByName, у меня это 52-я строка и код выглядит вот так:

Код
if ($listfields != ""){
$searchfields = $fieldmodel->[b]getFieldsByPosModule[/b]($listfields);
$field_values = $fieldmodel->getFieldValues();

7. заменяем выделенное жирным имя функции на то которое мы указали в начале поста когда копировали функцию, у нас это было getFieldsByPosModule
После внесенных изменений код должен выглядеть так:

Код
if ($listfields != ""){
$searchfields = $fieldmodel->getFieldsByPosModule($listfields);
$field_values = $fieldmodel->getFieldValues();

На этом все. Теперь поля в модуле будут показываться в том порядке, в котором мы их указали в настройках модуля.
*

moonaway

  • Осваиваюсь на форуме
  • 25
  • 0
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Модуль расширенного поиска самостоятельно

Автор magistr_yoda

Ответов: 14
Просмотров: 1241
Последний ответ 15.09.2017, 12:25:16
от Jazz12
Страница результатов поиска не в шаблоне

Автор Mick_20

Ответов: 1
Просмотров: 137
Последний ответ 26.05.2017, 12:01:15
от Mick_20
Изменить размер полей

Автор elipssp

Ответов: 10
Просмотров: 494
Последний ответ 24.01.2017, 23:14:28
от elipssp
[Решение!] VIP-объявления и монетизация доски объявлений adsmanager 2.6

Автор GlooM

Ответов: 139
Просмотров: 31236
Последний ответ 16.12.2016, 17:10:56
от Pita4ok
Модуль поиска - не сбрасываются результаты при переходе на другие страницы

Автор Ingener

Ответов: 9
Просмотров: 1353
Последний ответ 13.11.2016, 21:20:21
от moonaway