Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Samouchitel_po_razrabotke_rasshireny_dlya_Jooml....docx
Скачиваний:
3
Добавлен:
10.11.2018
Размер:
2.53 Mб
Скачать

Управление Коментариями

Мы добавили комментарии в ИА как особенность Компонента Обзоров.

К сожалению, не редки злоупотребления сайтами, которые предлагают размещать комментарии. Нам нужно построить в ИА менеджер для удаления или редактирования комментариев. Прежде, чем мы начнем писать код, вернемся в БД и добавим пункт меню внутри Обзоры Ресторанов (Restaurant Reviews) в меню Компоненты (Components).

Выполним запрос, чтобы получить id для текущего Компонента в ИА. В командной строке:

SELECT id FROM jos_components WHERE link = 'option=com_reviews';

Если вы используете PhpMyAdmin, просматривайте таблицу jos_components, пока не найдете строку для Restaurant Reviews и обратите внимание на значение в столбце id

После этого, введите следующий запрос в командной строке, подставляя вместо 34 ваше значение ID:

INSERT INTO jos_components (name, parent, admin_menu_link,

admin_menu_alt, ordering)

VALUES ('Manage Comments', 34,

'option=com_reviews&task=comments', 'Manage Comments', 1);

Если вы используете PhpMyAdmin, заполните поля, как показано на скриншоте для jos_components:

После обновления, вы должны заметить новое подменю:

Теперь, когда ссылка на месте, давайте добавим отображение для нее. В /administrator/components/com_reviews/controller.php, добавим такую функцию:

function comments()

{

global $option, $mainframe;

$limit = JRequest::getVar('limit',

$mainframe->getCfg('list_limit'));

$limitstart = JRequest::getVar('limitstart', 0);

$db =& JFactory::getDBO();

$query = "SELECT count(*) FROM #__reviews_comments";

$db->setQuery( $query );

$total = $db->loadResult();

$query = "SELECT c.*, r.name FROM #__reviews_comments

AS c LEFT JOIN #__reviews AS r ON r.id = c.review_id ";

$db->setQuery( $query, $limitstart, $limit );

$rows = $db->loadObjectList();

if ($db->getErrorNum())

{

echo $db->stderr();

return false;

}

jimport('joomla.html.pagination');

$pageNav = new JPagination($total, $limitstart, $limit);

HTML_reviews::showComments( $option, $rows, $pageNav );

}

Эта функция аналогична showReviews (), кроме того, что мы используем таблицу комментариев. В заключение вызываем HTML_reviews::showComments();, эту функцию мы сейчас и создадим. Откройте admin.reviews.html.php и добавьте следующий код в класс:

function showComments( $option, &$rows, &$pageNav )

{

?>

<form action="index.php" method="post" name="adminForm">

<table class="adminlist">

<thead>

<tr>

<th width="20">

<input type="checkbox" name="toggle"

value="" onclick="checkAll(<?php echo

count( $rows ); ?>);" />

</th>

<th class="title">Review Name</th>

<th width="15%">Commenter</th>

<th width="20%">Comment Date</th>

<th width="30%">Comment</th>

</tr>

</thead>

<?php

jimport('joomla.filter.output');

$k = 0;

for ($i=0, $n=count( $rows ); $i < $n; $i++) {

$row = &$rows[$i];

$checked = JHTML::_('grid.id', $i, $row->id );

$link = JOutputFilter::ampReplace( 'index.php?option=' .

$option . '&task=editComment&cid[]='. $row->id );

?>

<tr class="<?php echo "row$k"; ?>">

<td><?php echo $checked; ?></td>

<td><a href="<?php echo $link; ?>"><?php echo $row->name;

?></a></td>

<td><?php echo $row->full_name; ?></td>

<td><?php echo JHTML::Date($row->comment_date); ?></td>

<td><?php echo substr($row->comment_text, 0, 149); ?></td>

</tr>

<?php

$k = 1 - $k;

}

?>

<tfoot>

<td colspan="5"><?php echo $pageNav->getListFooter();

?></td>

</tfoot>

</table>

<input type="hidden" name="option"

value="<?php echo $option;?>" />

<input type="hidden" name="task" value="comments" />

<input type="hidden" name="boxchecked" value="0" />

</form>

<?php

}

По большей части, эта функция аналогична showReviews(). Мы создаем форму с именем adminForm, чтобы с ней мог работать встроенный JavaScript.

Заголовок таблицы содержит чекбокс, который переключает все флажки на экране одновременно. После заголовка, мы загружаем класс фильтрации выходных данных jimport ('joomla.filter.output'). Далее, присвоим $k = 0 для визуального эффекта затенения каждой второй строки таблицы (используя CSS класс).

За этим следует цикл по всем строкам комментариев. Мы создаем чекбокс и ссылку на каждый комментарий. Затем выводим строку таблицы с чекбоксом, ссылкой, именем комментатора, датой и текстом комментария. Ограничиваем текст комментария PHP-функцией substr(), так что администраторы могут видеть лишь часть каждого комментария.

После цикла, мы используем $pageNav функцию getListFooter() для обеспечения постраничной навигации. Наконец, присваиваем значение comments скрытой переменной task и название Компонента для option, чтобы мы могли вернуться назад на текущий экран вместо основного экрана при использовании постраничной навигации.

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

Выполните переход на Управление комментариями (Manage Comments). Экран должен выглядеть примерно так:

Также есть необходимость создать функции для редактирования, сохранения и удаление комментариев. Добавьте следующие функции в Контроллер в ИА:

function editComment()

{

global $option;

$row =& JTable::getInstance('comment', 'Table');

$cid = JRequest::getVar( 'cid', array(0), '', 'array' );

$id = $cid[0];

$row->load($id);

HTML_reviews::editComment($row, $option);

}

function saveComment()

{

global $option;

$row =& JTable::getInstance('comment', 'Table');

if (!$row->bind(JRequest::get('post')))

{

echo "<script> alert('".$row->getError()."');

window.history.go(-1);

</script>\n";

exit();

}

if (!$row->store()) {

echo "<script> alert('".$row->getError()."');

window.history.go(-1);

</script>\n";

exit();

}

$this->setRedirect('index.php?option=' . $option . '&task=comments',

'Comment changes saved');

}

function removeComment()

{

global $option;

$cid = JRequest::getVar( 'cid', array(), '', 'array' );

$db =& JFactory::getDBO();

if(count($cid))

{

$cids = implode( ',', $cid );

$query = "DELETE FROM #__reviews_comments WHERE id IN ( $cids )";

$db->setQuery( $query );

if (!$db->query())

{

echo "<script> alert('".$db->getErrorMsg()."');

window.history.go(-1);

</script>\n";

}

}

$this->setRedirect( 'index.php?option=' . $option . '&task=comments'

);

}

Эти функции аналогичны тем, что использовались для редактирования, сохранения и удаления Обзоров. Основным отличием является то, что мы не должны изменять никакие данные, прежде чем сохранить комментарии, а также мы не должны строить никакие HTML-элементы для отображения. Функция editComment() вызывает HTML_reviews::editComment(), которая конечно же нужно создать. Откройте admin.reviews.html.php и добавьте следующую функцию:

function editComment ($row, $option)

{

JHTML::_('behavior.calendar');

?>

<form action="index.php" method="post" name="adminForm"

id="adminForm">

<fieldset class="adminform">

<legend>Comment</legend>

<table>

<tr>

<td width="100" align="right" class="key">

Name:

</td>

<td>

<input class="text_area" type="text" name="full_name"

id="full_name" size="50" maxlength="250" value="<?php echo

$row->full_name;?>" />

</td>

</tr>

<tr>

<td width="100" align="right" class="key">

Comment:

</td>

<td>

<textarea class="text_area" cols="20" rows="4"

name="comment_text" id="comment_text"

style="width:500px"><?php echo $row->comment_text;

?></textarea>

</td>

</tr>

<tr>

<td width="100" align="right" class="key">

Comment Date:

</td>

<td>

<input class="inputbox" type="text" name="comment_date"

id="comment_date" size="25" maxlength="19" value="<?php echo

$row->comment_date; ?>" />

<input type="reset" class="button" value="..."

onclick="return showCalendar('comment_date', 'y-mm-dd');" />

</td>

</tr>

</table>

</fieldset>

<input type="hidden" name="id" value="<?php echo $row->id; ?>" />

<input type="hidden" name="option" value="<?php echo $option; ?>"

/>

<input type="hidden" name="task" value="" />

</form>

<?php

}

В начале функции добавляем JavaScript и CSS класс необходимые для впадающего календаря. Мы используем простой input для поля name и присваиваем ему CSS-класс text_area. Комментарий отображается в текстовой поле (textarea) с тем же CSS-классом. Наконец значение даты комментария в поле input с CSS-классом inputbox, в то время как кнопке, которая показывает всплывающий календарь, присвоен CSS-класс button. Эта кнопка вызывает JavaScript функцию showCalendar(), которая взаимодействует с полем comment_date для хранения даты в формате y-mm-dd. После мы добавляем скрытые параметры для id комментариев, имя Компонента в option, и пустышку task, которую JavaScript заполнит позже.

Нажав на ссылку на одном из комментариев, вы увидите подобный экран:

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]