Block.Pro.2.5

29.03
334
38 937
Block.Pro.2.5


Block.Pro.2 - Расширенный вывод блоков с новостями для DLE

Модуль для удобного и гибкого вывода новостей на любой странице DLE-сайта

Версия DLE: 9.5 (на других не проверялся, но работать должен)

Версия модуля: 2.5

Дата релиза: 29.03.2012

Автор: ПафНутиЙ

Контакты: http://pafnuty.name, Google+ или email

Модуль распространяется бесплатно для частного и коммерческого использования

При публикации модуля не забывайте оставлять ссылку на первоисточник, уважайте чужой труд.

Основные возможности модуля

  • Вывод популярных (топ по комментариям, рейтингу, просмотрам или как стандартный топ в dle), похожих, случайных (с возможностью отключения кеширования блока) или последних новостей.
  • Подключение модуля одной строкой непосредственно любой в шаблон (через include).
  • Простая и очень гибкая настройка вывода каждого блока.
  • Кеширование каждого блока (обновление кеша при добавлении новости или комментария на сайт) с возможностью отключения кеша для каждого блока.
  • Настройка категорий для вывода новостей (вывод только из определённых категорий, игнорирование определённых категорий, вывод или ингорирование новостей из просматриваемой категории)
  • Вывод уменьшенной копии картинки (в т.ч. и вместе с оригинальной картинкой) из короткой новости или дополнительного поля (картинки берутся только из папки uploads текущего сайта).
  • Автоматическое создание папки для уменьшенных копий изображений и выставление нужных прав.
  • Обрезка заголовка новости до заданного количества символов.
  • Обрезка текста новости (до заданного количества символов или до конца слова).
  • Ввод иконок категории.
  • Можно задать временной интервал для отбора новостей (по умолчанию 30дней).
  • Можно задать каждому блоку свой шаблон, свою картинку-заглушку.
  • Поддержка всех тегов, используемых в шаблонах кратких новостей.
  • Поддержка фильтра (перекрестные ссылки) по допполям, реализованного в DLE9.5
  • Можно указать с какой по счету новости начать вывод (например с 4й по 15ю).
  • Возможность быстрого редактирования новостей прямо из блока, аналогично стандартному функционалу

Установка модуля

  1. Скопировать файл block.pro.2.php в папку engine/modules/
  2. Скопировать содержимое папки THEME в папку с текущим шаблоном сайта
  3. В нужном месте прописать строку подключения модуля с обязательными параметрами:
    {include file="engine/modules/block.pro.2.php?&block_id=BLOCK&template=blockpro"}
    Где: BLOCK - Уникальный идентификатор блока blockpro - имя шаблона, используемого для вывода
  4. Настроить дополнительные параметры строки подключения и шаблон

Для вывода похожих новостей

  1. Отключить стандартный вывод похожих новостей в админке (Настройка системы » Оптимизация запросов к базе данных » Отображение похожих новостей » "нет")
  2. Открыть файл engine/modules/show.full.php перед
    if( $config['related_news']
    вставить
    /*Block.Pro - relatednews*/
    $block_id = 'related_'.$row['id']; //Не трогать!
    $relatedpro = "1"; //Не трогать!
    $template="relatednews"; // Имя шаблона (можно менять)
    include_once ENGINE_DIR . '/modules/block.pro.2.php';		
    /*Block.Pro - relatednews*/
  3. Настроить дополнительные переменные подключения модуля (Переменные приведены в таблице ниже. При вставке необходимо заменять символ & на $) и шаблон
  4. В ШАБЛОНЕ ПОЛНОЙ НОВОСТИ НИЧЕГО ДОПОЛНИТЕЛЬНО ПРОПИСЫВАТЬ НЕ НУЖНО! модуль выводится через стандартный тег похожих новостей.

Переменные строки подключения

Все переменные указываются непосредственно в строке подключения модуля.

В таблице дано описание возможных для использования переменных

Наименование переменной Значение по умолчанию Описание Примечание
&block_id   Обязательная переменная. Уникальный идентификатор блока любое, уникальное для каждого блока значение
&template   Обязательная переменная. Имя шаблона для вывода блока указывается только имя, без расширения .tpl
&day 30 Количество дней, за которое осуществляется отбор новостей. Если указать ноль (0) - будут браться новости за всё время. Переменная автоматически принимает нулевое значение, если в строке подключения определена переменная &last, &relatedpro или &rndom
&show_cat   Категория/категории для отбора новостей.

Категории указываются через запятую.

Если указать &show_cat=this - новости будут браться только из просматриваемой категории.

&ignore_cat   Модификатор переменной &show_cat. превращает указанные в &show_cat категории в игнорируемые. Для активации модификатора достаточно его определить (например &ignore_cat=y)
&start_from 0 Начало диапазона отбора новостей.  
&news_num 10 Количество новостей в блоке  
&img_xfield   Имя дополнительного поля для получения уменьшенного изображения.

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

Одновременный вывод картинки из краткого содержимого и допполя невозможен.

В допполе должна лежать прямая ссылка на изображение.

&img_size 60x60 Размер уменьшенной копии изображения. (Ширина X Высота) Допустимо указывать одну цифру (например 100). тогда изображение будет уменьшено по большей стороне. при указании нуля (&img_size=0) изображение обрезаться не будет.
&noimage noimage.png Имя и расширение для картинки-заглушки, в случаи отсутствия изображения в новости. Картинка-заглушка должна располагаться в папке images текущего шаблона сайта.
&nocache   Модификатор, отключающий использование кеша для блока. Для активации модификатора достаточно его определить (например &nocache=y)

 

&random

&last

&top_comm

&top_rating

&top_views

 

Варианты сортировки новостей.

Случайным образом

По дате добавления

Самые комментируемые

Самые рейтинговые

Самые часто просматриваемые

По умолчанию выводятся топ-новости (по аналогии со стандартным топом DLE)

Недопустимо использование нескольких вариантов сортировки одновременно.

&wordcut   Модификатор, отключающий обрезку текста новости до конца слова и включающий обрезку до заданного количества символов. Для активации модификатора достаточно его определить (например &wordcut=y)
$relatedpro   Модификатор активирует механизм отображения похожих новостей. Указывается только при подключении модуля в файле show.full.php для вывода похожих новостей. Для активации модификатора достаточно его определить (например $relatedpro=y;)


Теги шаблона

В таблице приведены возможные для использования в шаблоне теги и их описание.

Обозначение тега шаблона Описание Примечание
{link-category} Ссылка/ссылки на категории  
{category} Наименование категории  
{category-icon} Иконка/иконки категорий При отсутствии иконки берётся картинка {THEME}/images/no_icon.gif
[xfvalue_name] Значение дополнительного поля "name", где "name" название дополнительного поля  
[xfgiven_name] [xfvalue_name] [/xfgiven_name] Выводится дополнительное поле "name", если поле не пустое, если поле не имеет значения, то текст просто вырезается  
[xfnotgiven_name] текст [/xfnotgiven_name] Выводят текст указанный в тегах, если дополнительное поле не было задано при публикации новости, где "name" это имя дополнительного поля  
{image-X} Выводит URL уменьшенной картинки находящейся в краткой новости, где Х это номер картинки в новости, например {image-1} выведет URL первой картинки в краткой новости  
{image_original} Выводит URL оригинальной картинки, указанной в {image-X}  
[image_original] текст [/image_original] Выводят текст указанный в тегах, если есть {image_original}  
[not_image_original] текст [/not_image_original] Выводят текст указанный в тегах, если нет {image_original}  
{rating} Выводит рейтинг  
{vote-num} Выводит количество проголосовавших  
[profile] текст [/profile] Выводят прямую ссылку на профиль автора публикации, без использования всплывающего окна минипрофиля.  
{login} Выводит логин пользователя добавившего новость в виде обычной текстовой информации без ссылок на профиль и карточку пользователя.  
{author} Ссылка на автора новости  
{date} Дата новости в формате, установленном в настройках движка  
{date=X} Дата новости в пользовательском формате  
Block.Pro.2.5 Заголовок новости  
{title limit="X"} Заголовок новости, обрезанный до X символов.  
{text} Текст новости (аналог {short-story})  
{text limit="X"} Текст новости, обрезанный до указанного X количества символов, при этом обрезание текста происходит до последнего логического слова, а не обрывает текст на середине слова.  
{full-link} URL полной новости  
{comments-num} Количество комментариев к новости  
{views} Количество просмотров новости  
[edit] текст [/edit] Ссылка на редактирование новости  



Техническая поддержка модуля осуществляется только по указанным контактным данным

Но это не означает, что техподдержка будет оказана :)

P.S. Пример использования модуля вы можете лицезреть на этом сайте, прямо чуть ниже ссылки на скачивание выводятся похожие новости.

ВНИМАНИЕ!

Все обсуждения модуля теперь только в этой теме или на сайте blockpro.ru

Похожие материалы

Комментарии

fender
fender 5 апреля 2012 13:56
А как исключить не нужные категории в похожих новостях?
ПафНутиЙ
ПафНутиЙ 5 апреля 2012 14:04
Нужно:
3. Настроить дополнительные переменные подключения модуля (Переменные приведены в таблице ниже. При вставке необходимо заменять символ & на $)
fender
fender 5 апреля 2012 14:09
А блин, что туплю то wink
извиняюсь
fender
fender 5 апреля 2012 15:19
еще вопрос, как вывести средний рейтинг новости? (только цифры)
ПафНутиЙ
ПафНутиЙ 5 апреля 2012 15:20
А как вы выводите средний рейтинг у обычных новостей?
fender
fender 5 апреля 2012 15:28
вывожу тегом {rating}
и все настраиваю в functions.php
ПафНутиЙ
ПафНутиЙ 5 апреля 2012 15:29
ну так настройте так же и в block.pro.php Там вывод рейтинга осуществляется по аналогии с show.full.php
feedalt
feedalt 6 апреля 2012 16:26
Как сделать чтоб вывод новостей в топе был с определенной категории?
Mr. Hyde
Mr. Hyde 6 апреля 2012 16:50
в строку добавления добавить &category=1,2,3. Вроде в мануале, это написанно
feedalt
feedalt 6 апреля 2012 17:04
Все сам разобрался. Вот еще что например я хочу чтоб в топе отображались самые скачивание файлы и с количеством скачиваний чтоб количество бралось от оттачмента, приведи примеры на скринах:

Mr. Hyde
Mr. Hyde 6 апреля 2012 21:30
Все "просто", переписываем модуль. Меняем таблицу dle_post на dle_files, сортируем по dcount. Далее ищем новость в таблице с dle_post с id - news_id. Или же пишем мне в icq и я вам, это сделаю за небольшую сумму.
ПафНутиЙ
ПафНутиЙ 6 апреля 2012 21:32
Модуль не поддерживает отображение аттачей. Если нужно - правьте самостоятельно, смотрите как устроен вывод аттачей в show.short.php и делайте так же. Мне это не интересно.
P.S. И не нужно спамить в комментариях.
feedalt
feedalt 6 апреля 2012 21:49
Кто может сделать?
kiosaki
kiosaki 7 апреля 2012 19:13
Здравствуйте!
У меня с картинками проблема, почему-то везде в этих блоках вставляется noimage, а не картинка из новости.
Подскажите, пожалуйста, в чем может быть причина? Куда капать?
ПафНутиЙ
ПафНутиЙ 7 апреля 2012 21:53
Проверьте наличие картинок в новостях.
Картинки должны быть на текущем сайте в папке uploads (и подпапках этой папки).
Напишите строку подключения сюда.
kiosaki
kiosaki 8 апреля 2012 02:45
ПафНутиЙ,
оу, у меня все рисунки залиты на внешние источники, новостей очень много, для экономии места. И потому их нету в папке upload...
Так модуль нельзя использовать в таком случае?
ПафНутиЙ
ПафНутиЙ 8 апреля 2012 09:31
С картинками - нет. Если картинки не выводить - юзайте наздоровье.
Mr. Hyde
Mr. Hyde 8 апреля 2012 11:10
Почему нельзя? Можно! Просто не делать обрезку, а выводить оригинал.
ПафНутиЙ
ПафНутиЙ 8 апреля 2012 12:45
Так в том и суть, чтобы вывести нужную картинку в нужном месте, так то можно и на custom всё вывести )))
kiosaki
kiosaki 8 апреля 2012 23:54
ПафНутиЙ,
На кастоме не выведешь по рейтингу из определенных категорий.
В этом и самая ценность вашего модуля для меня - выводить топы из разных категорий.
Т.е. с картинками в моем случае (не залитыми на мой сервер) никак, да? (
ПафНутиЙ
ПафНутиЙ 9 апреля 2012 07:12
Можно отключить проверку путей картинок, но это 100% приведёт рано или поздно к белому экрану с надписью
Not Supported File! Thumbnails can only be made from .jpg, gif and .png images!
kiosaki
kiosaki 9 апреля 2012 19:28
Понял, окей, спасибо, значит без картинок буду использовать.
Alexx
Alexx 9 апреля 2012 20:52
Доброго времени суток!
Спасибо, за отличный модуль и, собственно вопрос - как организовать сортировку новостей по дате добавления но по возрастанию (т.е. сначала старые - потом новые, сейчас при модификаторе &last выводится по убыванию).

Заранее спасибо.
ПафНутиЙ
ПафНутиЙ 9 апреля 2012 21:29
В модуле
date DESC
заменить на
date ASC
Alexx
Alexx 9 апреля 2012 21:36
Большое спасибо за оперативность.
OKyJIucT
OKyJIucT 13 апреля 2012 01:29
Обнаружил такую особенность на DLE 9.5 - {category-url} данный тег не выводит ссылку на категорию, в которой находится новость, если она выводится при помощи данного модуля.
OKyJIucT
OKyJIucT 13 апреля 2012 01:35
Однако {link-category} даже удобней в моем случае, не требует дополнительного форматирования wink
Спасибо feel
ПафНутиЙ
ПафНутиЙ 13 апреля 2012 07:38
так и задумано.
{category-url} в модуле заменён на более удобный тег {link-category}
P.S. хотя вот только что обратил внимание, что иконку-ссылку на категорию сделать не получится... и title у ссылки нет.
opener
opener 14 апреля 2012 03:48
Не выводит новости по дате добавления -
{include file="engine/modules/block.pro.2.php?&block_id=main&template=bpro_main&nocache=y&show_cat=1&last"}

по прежнему выводятся по просмотрам. &random тоже не работает. В модуле вообще ничего не изменял.
date ASC тоже не ничего не изменила.
ПафНутиЙ
ПафНутиЙ 14 апреля 2012 09:09
{include file="engine/modules/block.pro.2.php?&block_id=main&template=bpro_main&nocache=y&show_cat=1&last=1"}

переменная last не определена была.

Добавить комментарий

Комментировать могут только зарегистрированные пользователи

Информация

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