Мы в твиттере Мы в телеграме!

Провеббер » DataLife Engine » DLE хаки » Настройка сортировки для тега {custom}

Набор в команду! Ведется набор в команду, для наполнения сайта новым, интересным контентом. Если у тебя есть предложения, свободное время, ты обладаешь интересным контентом, и хочешь поделиться с другими?
Обращайся к нам в ЛС группы Вконтакте.

Настройка сортировки для тега {custom}

Данный материал предоставлен сайтом ProWebber.cc исключительно в ознакомительных целях. Администрация не несет ответственности за его содержимое.
Скачать бесплатно Настройка сортировки для тега {custom}.

Приветствую вас, товарищи веб мастера. Буквально вчера мне пришлось работать со стандартным тегом {custom}, которые украшает DLE своим наличием долгие годы

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

Я же решил обойтись без лишних изысков и всё-таки модифицировать кастом, добавив в параметры тега, параметр определяющий поле для сортировки и тип сортировки.

Пожалуй, начнем устанавливать.
Нужно открыть файл /index.php

Найти в нём:


if (stripos ( $tpl->copy_template, "{custom" ) !== false) {
    $tpl->copy_template = preg_replace ( "#\\{custom category=['\"](.+?)['\"] template=['\"](.+?)['\"] aviable=['\"](.+?)['\"] from=['\"](.+?)['\"] limit=['\"](.+?)['\"] cache=['\"](.+?)['\"]\\}#ies", "custom_print('\\1', '\\2', '\\3', '\\4', '\\5', '\\6', '{$dle_module}')", $tpl->copy_template );
}

Заменить на:


if (strpos ( $tpl->copy_template, "{custom" ) !== false) {
    $tpl->copy_template = preg_replace ( "#\\{custom category=['\"](.+?)['\"] template=['\"](.+?)['\"] aviable=['\"](.+?)['\"] from=['\"](.+?)['\"] limit=['\"](.+?)['\"] order=['\"](.+?)['\"] by=['\"](.+?)['\"] cache=['\"](.+?)['\"]\\}#ies", "custom_print('\\1', '\\2', '\\3', '\\4', '\\5', '\\6', '\\7', '\\8', '{$dle_module}')", $tpl->copy_template );
}


Пол дела сделано :)

Осталось описать их в функции custom_print();

Для этого открываем файл engine/modules/functions.php

Найти :


function custom_print($custom_category, $custom_template, $aviable, $custom_from, $custom_limit, $custom_cache, $do) {


Заменить на:


function custom_print($custom_category, $custom_template, $aviable, $custom_from, $custom_limit, $custom_order, $custom_by, $custom_cache, $do) {


Найти:


if( $cat_info[$custom_category]['news_sort'] != "" ) $news_sort = $cat_info[$custom_category]['news_sort']; else $news_sort = $config['news_sort'];
if( $cat_info[$custom_category]['news_msort'] != "" ) $news_msort = $cat_info[$custom_category]['news_msort']; else $news_msort = $config['news_msort'];

Заменить на:


if($custom_order != "0")
    $news_sort = $custom_order;
elseif( $cat_info[$custom_category]['news_sort'] != "" )
    $news_sort = $cat_info[$custom_category]['news_sort'];
else
    $news_sort = $config['news_sort'];

        
if($custom_by != "0")
    $news_msort = $custom_by;
elseif( $cat_info[$custom_category]['news_msort'] != "" )
    $news_msort = $cat_info[$custom_category]['news_msort'];
else     
    $news_msort = $config['news_msort'];


Теперь тег custom выглядит следующим образом:

{custom category="2,7" template="custom" aviable="global" from="0" limit="10" order="rating" by="DESC" cache="yes"}

Теперь небольшой мануал по возможным параметрам сортировки.
Вышеописанный тег выводит новости сортируя их по рейтингу по убыванию (Сверху новости с самым высоким рейтингом)
Теперь вспомним какие поля имеются у DLE в таблицу dle_post:

title – Если написать в качестве параметра title, то сортировка будет производится по алфавиту. Рекомендую в этом случае в качестве параметра by использовать всётаки ASC, ибо вывод начнётся со статей на букву А.

rating – Рейтинг статьи
date – Дата публикации
comm_num – Количество комментариев
news_read – Количество просмотров
Думаю этого хватит

Теперь о параметре by

Тут есть два возможных варианта:

1.ASC – Сортирует по возрастанию (1,2,3,4,5)
2.DESC – Сортирует по убыванию (5,4,3,2,1)

Собственно на этом всё. Хочу напомнить. Если параметры order="0" и by="0" оставить с нулями, то будут учиться параметры сортировки в категории, для которой установлен тег (Вроди бы срабатывает, если категория одна). Иначе выводит в связи с конфигурацией движка. Тоесть по дате и по убыванию (Настраивается в конфиге движка :)


Дополнительные ссылки на скачивание ТОЛЬКО для зарегистрированных


-1
Просмотры: 6 941 :: Комментарии (6) :: :: Нужна помощь? Задайте вопрос на форуме ::
Уважаемый посетитель, Вы зашли на сайт как незарегистрированный пользователь.
Мы рекомендуем Вам зарегистрироваться либо войти на сайт под своим именем.

#1skelani

  • 10 июля 2011 21:05
  • Регистрация: 28.09.2010
  • Был(а) онлайн: 4.09.2016
  • Комментариев: 55
  • 0
Добавь скришонтов ато не понятно сразу

#2mlevox

  • 10 июля 2011 21:55
  • Регистрация: 4.11.2010
  • Был(а) онлайн: 11.02.2015
  • Комментариев: 4
  • 0
А что непонятного? По стандарту тег custom выводит последние материалы из определенно категории. Этот хак позволяет выводить самые рейтинговые, комментируемые и просматриваемые.

#3atlas100

  • 13 июля 2011 10:48
  • Регистрация: 7.11.2009
  • Был(а) онлайн: 8.11.2013
  • Комментариев: 15
  • 0
Попробуй еще реализовать возможность сортировки за период , по просмортрам.

#4rashpil

  • 17 июля 2011 23:48
  • Регистрация: 25.12.2009
  • Был(а) онлайн: 4.04.2016
  • Комментариев: 123
  • 0
atlas100, Тоже не сложно. Можно же передавать через параметры сорт и бай не только параметры сортировки в SQL. Достаточно написать в них же временные интервалы в формате публикации новостей, а в коде обработки тега (Функция custom_print();) написать регулярное выражение. И если оно отдаст тру, то в запросе определить временной интервал даты новости по переданным параметрам. В прочем, стучитесь в аську 419694531, помогу если что

#5Molen

  • 22 июля 2011 18:18
  • Регистрация: 22.07.2011
  • Был(а) онлайн: 22.11.2012
  • Комментариев: 53
  • 0
Отличный хак, спасибо.

#6Albion

  • 25 июля 2011 12:54
  • Регистрация: 12.01.2011
  • Был(а) онлайн: 5.02.2013
  • Комментариев: 14
  • 0
Хорошее расширение функциональности.

Информация
Посетители, находящиеся в группе Гости, не могут оставлять комментарии к данной публикации.

Архив новостей
Ноябрь 2024 (1)
Октябрь 2024 (171)
Сентябрь 2024 (13)
Август 2024 (61)
Июль 2024 (12)
Июнь 2024 (30)

Последние комментарии: