Последняя версия
1.9.1

Экологически чистая система комментирования

Документация

страница в процессе наполнения...

Описание дистрибутива

Весь дистрибутив скрипта состоит из четырех файлов:

ecomment.php
Это серверная часть скрипта, обслуживающая AJAX-запросы от страницы с подключенным комментированием.
ecomment.js
Клиентская часть скипта, которая будет отправлять AJAX-запросы на серверную сторону.
ecomment.css
Стилевое оформление списка комментариев. Легко кастомизируется под дизайн вашего сайта простой сменой цветов.
test_page.html
Тестовая страница скрипта с примером интеграции. Для работы должна быть помещена в ту же папку, где лежат предыдущие три файла. Содержит в себе пример инициализации скрипта комментирования.
ecomment_connector.php

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

Размещение файлов на сервере

Обязательными для работы скрипта являются первые три файла из перечисленных выше + подключенный на странице фреймворк jQuery (в дистрибутив не входит).

Все файлы необходимо разместить в одной папке и настроить в самих скриптах корректные пути. Лучше всего использовать абсолютные пути - от корня сайта, начинаяются со слеша "/".

Все дальнейшие примеры приводятся с условием размещения файлов в корне сайта.

В файле ecomment.js указываем путь до размещения ecomment.php:


    settings = $.extend({
        'ref'		: location.href,
        'http_ref'	: location.href,
        'path' 		: '/ecomment.php'
    }, options),

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

Так же на хосте необходимо создать папку для хранения файлов данных с комментариями. Корректный путь до нее необходимо указать в серверной части скрипта ecomment.php:


class ecomment {
    //основные настройки
    private $store = "/store/";
    ...

Подключение стилей и плагина

Для корректного отображения комментариев необходимо подключить в заголовке страницы (между <HEAD> и </HEAD> ) файл стилей ecomment.css и сам плагин ecomment.js.


    <link rel="stylesheet" href="/ecomment.css" type="text/css" media="all">
    <script type="text/javascript" src="/ecomment.js"></script>

Содержимое файла ecomment.css можно перенести в ваш основной файл стилей. В таком случае, отдельно подключать этот файл уже не нужно, что благоприятно скажется на производительности.

Все правки внешнего вида комментариев удобнее будет вносить в отдельный css-Файл (или ваш основной стиль), не затрагивая сам ecomment.css. В будущем, это позволит вам легко обновлять версию скрипта целиком, без повторного внесения правок в ecomment.css.

Инициализация комментариев

Для инициализации комментариев необходимо в нужном месте разметки вашей страницы разместить пустой контейнер и навесить на него сам плагин. После загрузки скрипт самостоятельно создает необходимые HTML-контейнеры, обвешивает их JS-скриптами и делает первый AJAX-запрос к серверной части ecomment.php для получения списка комментариев, принадлежащих текущей странице. Плагин может принимать объект с параметрами инициализации. Например, можно передать ref параметр для вывода комментариев определенной страницы, не пренадлежащих той, с которой запускается скрипт. Такой пример включен в тестовую страницу дистрибутива.


    <div class="ecomment_wrapper"></div>
    <script>
    // одиночное подключение скрипта на странице
    $('.ecomment_wrapper').ecomment()
    </script>

    <div class="ecomment_wrapper" rel="some_ref_one"></div>
    <div class="ecomment_wrapper" rel="some_ref_two"></div>
    <script>
        // многократное подключение скрипта на странице
        $('.ecomment_wrapper').each(function(){
            $(this).ecomment({
                ref: $(this).attr('rel')
            });
        });
    </script>

В примере с многократным подключением в параметре rel передается идентификатор страницы, с которой будут браться комментарии. Например, вы можете выводить на главной странице сайта блок с "последними отзывами" и блок с сообщениями из рубрики "вопрос-ответ".


    <div class="ecomment_wrapper" rel="http://mysite.com/feedback.html"></div>
    <div class="ecomment_wrapper" rel="http://mysite.com/faq.html"></div>

ВАЖНО!

Некоторые вопросы в комментариях могут остаться без ответа без объяснения причин. Основная причина в таких случаях - или я его еще не прочитал, или ответ уже много раз звучал ранее. Не поленитесь полистать комментарии и воспользоваться поиском.

... когда-нибудь я сделаю раздел FAQ и перестану отвечать на вопросы в комментах :)

08.12.2012 01:06
+ 0 -
Лев Выскубов
Скрипт понравился, пока пробовал на локальном сервере. На боевом сервере использую кодировку Win-1251. Когда поменял кодировку в файлах ecomment.js и ecomment.php - работать перестало полностью. Если только в js - работает нормально.
Спасибо!
14.12.2012 20:03
+ 0 -
Женя
Скриптик отличный, устанавливается просто, просто внедряется в дизайн.

Пожелания (думаю остальные пользователи, меня поддержат):Еще хотелось бы видеть вставку смайлов и нумерацию всех сообщений, которые размещены на сайте (вроде этого: Комментарий №2322, Комментарий №2323 и т.д.).

А в общем спасибо разработчику за скрипт!
14.12.2012 20:13
+ 0 -
Женя
Да, и еще пара:

маленький вопросик - где посмотреть модератору email отправителя, кроме как в своей почте.

и просьба - сделать возможность загружать аватары пользователем перед отправкой сообщения (или выбор из базы аватарок)

и, возможно можно сделать черный список слов, которые заменяются на *, когда режим премодерации отключен?
14.12.2012 20:21
+ 0 -
Женя
И еще одно (извиняюсь за настойчивость), вопрос личного характера:

скрипт комментариев помещен во вкладку, на вкладке (на заголовке) есть div, можно-ли вывести в этот div число комментариев "всего на данной странице (число) комментариев"

Заранее спасибо.
15.12.2012 13:38
+ 0 -
Геннадий
1. Вставка смайлов - не предусматривается. Ни bbcode, ни к-либо друга дополнительная разметка. Только чистый текст.
2. Общая нумерация сообщений - невозможно. В момент исполнения скрипт может знать количество сообщений только на данной конкретной странице. Чтобы узнать количество сообщений на других страницах, нужно перечитать все файлы с комментами - это долго и тяжко для сервера. Ради сомнительной нужды нумерации это делаться не будет, так как противоречит концепции минимальной нагрузки на сервер.
3. Имейл посмотреть негде (разве что в файле с комментами). Вопрос принят в рассмотрение - возможно, будет добавлено в следующей версии.
4. Загрузки аватар однозначно не будет - во-первых, противоречит концепции "экологичности" скрипта (работать без лишнего мусора - накопится оооочень много одноразовых аватар), во-вторых, любая загрузка файлов - это потенциальная дыра в безопасности, появление которой лучше избежать вовсе.

Оставить комментарий

Имя:
Email:
Комментарий:
- я не робот
eComment v.1.9.3

Новости

21.09.2016

Обновление 1.9.1

Пакет правок по заявкам пользователей.…
04.07.2016

Пожелания к обновлению

Сбор пожеланий от пользователей для очередного обновления функционала скрипта…
12.05.2015

Обновление 1.8.1

Небольшие косметические правки.…
Все новости


Обращение к незаданной переменной post
Указанная операция "get_list" не существует