Хак Вывод количества новостей с категорий за сегодня и за общее время для DLE 9.6 - 11.x

PunPun

Coder
Команда форума
Приватовец
Регистрация
23 Фев 2017
Сообщения
618
Реакции
402
Баллы
63
Хак позволит вывести в нужном месте количество новостей с категорий за сегодня или за все время. В хаке присутствует кэширование что уменьшает нагрузку.

Установка хака Вывод количества новостей с категорий за сегодня и за общее время для DLE:
1. Открываем /engine/modules/main.php находим:
PHP:
$tpl->compile ( 'main' );
Выше вставляем:
PHP:
if (strpos ( $tpl->copy_template, "{cat_all" ) !== false) {
    $tpl->copy_template = preg_replace_callback( "#{cat_all\:(.+?)}#is", function($data) use ($db, $config)
    {
       return catCountFunction($data, $config, $db);
    }, $tpl->copy_template );
}
if (strpos ( $tpl->copy_template, "{cat_today" ) !== false) {
    $tpl->copy_template = preg_replace_callback( "#{cat_today\:(.+?)}#is", function($data) use ($db, $config)
    {
       return catCountFunction($data, $config, $db, true);
    }, $tpl->copy_template );
}
2. Открываем /engine/modules/functions.php находим:
PHP:
function get_url($id) {
Выше вставляем:
PHP:
function catCountFunction($cat_id, $config, $db, $curdate = false)
{
    $cat_ids = array();
    if(substr_count($cat_id[1], ","))
        $cat_ids = explode(",", $db->safesql(trim(strip_tags(stripslashes($cat_id[1])))));
    else
        $cat_ids[] = is_numeric($cat_id[1]) ? intval($cat_id[1]) : false;
    if(!count($cat_ids)) return;

    $cache_cat_news = false;
    $cache_cat_news = dle_cache("news_acn" . intval($curdate), $config['skin'] . implode($cat_ids), false);
 
    if ($config['allow_multi_category'])
        $cat_query = "category regexp '[[:<:]](" . implode ( '|', $cat_ids ) . ")[[:>:]]'";
    else
        $cat_query = "category IN ('" . implode ( "','", $cat_ids ) . "')";
    if (!$cache_cat_news)
    {
        if($curdate == false)
            $row = $db->super_query( "SELECT COUNT(*) as count FROM " . PREFIX . "_post WHERE {$cat_query}");
        else
            $row = $db->super_query( "SELECT COUNT(*) as count FROM " . PREFIX . "_post WHERE {$cat_query} AND date LIKE '".date("Y-m-d")."%'");
        $newscount = ($row['count'] > 0) ? intval($row['count']) : false;
        if($newscount)
            $cache_cat_news = $newscount;
        create_cache("news_acn" . intval($curdate), $cache_cat_news, $config['skin'] . implode($cat_ids), false);
    }

    return ($cache_cat_news > 0 ? (($curdate == true) ? "+" : "") . $cache_cat_news : "");
}
Использование:
В нужном месте доступны теги:
{cat_all:1} или {cat_all:1,2,3,4} - выведет количество новостей за все время с этих категорий.
{cat_today:1} или {cat_today:1,2,3,4} - выведет количество новостей за сегодня с этих категорий.

Ссылка на автора: https://punpun.name/
 
Последнее редактирование:

Kubo

Приватовец
Приватовец
Регистрация
27 Фев 2017
Сообщения
42
Реакции
15
Баллы
8
Спасибо за хак. Возможно, как-то сделать, чтобы было так [cat_all]{cat_all:1}[/cat_all] ??? Заранее спасибо
 

danila_11

Новичок
Регистрация
30 Июл 2017
Сообщения
121
Реакции
9
Баллы
18
@PunPun, а dle 13.1 будет работать?
 
Сверху Снизу