Файл: InstantSocial/uploud/admin/components/comments/backend.php
Строк: 488
<?php
if(!defined('VALID_CMS_ADMIN')) { die('ACCESS DENIED'); }
/******************************************************************************/
// //
// InstantCMS v1.9 //
// http://www.instantcms.ru/ //
// //
// written by InstantCMS Team, 2007-2011 //
// produced by InstantSoft, (www.instantsoft.ru) //
// //
// LICENSED BY GNU/GPL v2 //
// //
/******************************************************************************/
function cpStripComment($text){
if (sizeof($text) < 120) { return $text; }
return substr($text, 0, 120) . '...';
}
cpAddPathway('Комментарии пользователей', '?view=components&do=config&id='.$_REQUEST['id']);
if (isset($_REQUEST['opt'])) { $opt = $_REQUEST['opt']; } else { $opt = 'list'; }
$toolmenu = array();
if ($opt!='list'){
$toolmenu[1]['icon'] = 'listcomments.gif';
$toolmenu[1]['title'] = 'Все комментарии';
$toolmenu[1]['link'] = '?view=components&do=config&id='.$_REQUEST['id'].'&opt=list';
}
if ($opt!='config'){
$toolmenu[2]['icon'] = 'config.gif';
$toolmenu[2]['title'] = 'Настройки компонента';
$toolmenu[2]['link'] = '?view=components&do=config&id='.$_REQUEST['id'].'&opt=config';
}
cpToolMenu($toolmenu);
//LOAD CURRENT CONFIG
$cfg = $inCore->loadComponentConfig('comments');
$inCore->loadModel('comments');
$model = new cms_model_comments();
$inDB = cmsDatabase::getInstance();
if($opt=='saveconfig'){
$cfg = array();
$cfg['email'] = $inCore->strClear($_REQUEST['email']);
$cfg['canguests'] = (int)$_REQUEST['canguests'];
$cfg['regcap'] = (int)$_REQUEST['regcap'];
$cfg['publish'] = (int)$_REQUEST['publish'];
$cfg['smiles'] = (int)$_REQUEST['smiles'];
$cfg['bbcode'] = (int)$_REQUEST['bbcode'];
$cfg['selfdel'] = (int)$_REQUEST['selfdel'];
$cfg['subscribe'] = (int)$_REQUEST['subscribe'];
$cfg['anchors'] = (int)$_REQUEST['anchors'];
$cfg['recode'] = (int)$_REQUEST['recode'];
$cfg['min_karma'] = (int)$_REQUEST['min_karma'];
$cfg['min_karma_show'] = (int)$_REQUEST['min_karma_show'];
$cfg['min_karma_add'] = (int)$_REQUEST['min_karma_add'];
$cfg['perpage'] = (int)$_REQUEST['perpage'];
$cfg['cmm_ajax'] = (int)$_REQUEST['cmm_ajax'];
$cfg['cmm_ip'] = (int)$_REQUEST['cmm_ip'];
$cfg['max_level'] = (int)$_REQUEST['max_level'];
$cfg['edit_minutes'] = (int)$_REQUEST['edit_minutes'];
$inCore->saveComponentConfig('comments', $cfg);
$inCore->redirect('index.php?view=components&do=config&id='.$_REQUEST['id'].'&opt=list');
}
if ($opt == 'show_comment'){
if(isset($_REQUEST['item_id'])) {
$id = $_REQUEST['item_id'];
$sql = "UPDATE cms_comments SET published = 1 WHERE id = $id";
dbQuery($sql) ;
echo '1'; exit;
}
}
if ($opt == 'hide_comment'){
if(isset($_REQUEST['item_id'])) {
$id = $_REQUEST['item_id'];
$sql = "UPDATE cms_comments SET published = 0 WHERE id = $id";
dbQuery($sql) ;
echo '1'; exit;
}
}
if ($opt == 'update'){
if(isset($_REQUEST['item_id'])) {
$id = $inCore->request('item_id', 'int');
if (isset($_REQUEST['guestname']) && @!empty($_REQUEST['guestname'])) { $guestname = $inCore->request('guestname', 'str'); }
else { $guestname = ''; }
$pubdate = $inCore->request('pubdate', 'str');
$published = $inCore->request('published', 'int');
$content = $inCore->request('content', 'html');
$content = $inDB->escape_string($content);
$sql = "UPDATE cms_comments
SET guestname = '$guestname',
pubdate = '$pubdate',
published=$published,
content='$content'
WHERE id = $id
LIMIT 1";
dbQuery($sql) ;
header('location:index.php?view=components&do=config&id='.(int)$_REQUEST['id'].'&opt=list');
}
}
if($opt == 'delete'){
if(isset($_REQUEST['item_id'])) {
$id = (int)$_REQUEST['item_id'];
$model->deleteComment($id);
header('location:index.php?view=components&do=config&id='.$_REQUEST['id'].'&opt=list');
}
}
if ($opt == 'list'){
cpAddPathway('Все комментарии', '?view=components&do=config&id='.$_REQUEST['id'].'&opt=list');
echo '<h3>Все комментарии</h3>';
//TABLE COLUMNS
$fields = array();
$fields[0]['title'] = 'id'; $fields[0]['field'] = 'id'; $fields[0]['width'] = '30';
$fields[1]['title'] = 'Дата'; $fields[1]['field'] = 'pubdate'; $fields[1]['width'] = '100';
$fields[2]['title'] = 'Текст'; $fields[2]['field'] = 'content'; $fields[2]['width'] = '';
$fields[2]['prc'] = 'cpStripComment';
$fields[3]['title'] = 'IP'; $fields[3]['field'] = 'ip'; $fields[3]['width'] = '80';
$fields[4]['title'] = 'Показ'; $fields[4]['field'] = 'published'; $fields[4]['width'] = '50';
$fields[4]['do'] = 'opt'; $fields[4]['do_suffix'] = '_comment';
$fields[5]['title'] = 'Автор'; $fields[5]['field'] = 'id'; $fields[5]['width'] = '180';
$fields[5]['prc'] = 'cpCommentAuthor';
$fields[6]['title'] = 'Цель'; $fields[6]['field'] = 'id'; $fields[6]['width'] = '220';
$fields[6]['prc'] = 'cpCommentTarget';
//ACTIONS
$actions = array();
$actions[0]['title'] = 'Редактировать';
$actions[0]['icon'] = 'edit.gif';
$actions[0]['link'] = '?view=components&do=config&id='.$_REQUEST['id'].'&opt=edit&item_id=%id%';
$actions[1]['title'] = 'Удалить';
$actions[1]['icon'] = 'delete.gif';
$actions[1]['confirm'] = 'Удалить комментарий?';
$actions[1]['link'] = '?view=components&do=config&id='.$_REQUEST['id'].'&opt=delete&item_id=%id%';
//Print table
cpListTable('cms_comments', $fields, $actions, '', 'pubdate DESC');
}
if($opt=='edit'){
if(isset($_REQUEST['item_id'])){
$id = $_REQUEST['item_id'];
$sql = "SELECT * FROM cms_comments WHERE id = $id LIMIT 1";
$result = dbQuery($sql) ;
if (mysql_num_rows($result)){
$mod = mysql_fetch_assoc($result);
if($mod['user_id']==0) { $author = '<input name="guestname" type="text" id="title" size="30" value="'.@$mod['guestname'].'"/>'; }
else {
$usersql = "SELECT * FROM cms_users WHERE id = ".$mod['user_id'];
$userres = dbQuery($usersql) ;
$u = mysql_fetch_assoc($userres);
$author = $u['nickname'].' (<a target="_blank" href="/admin/index.php?view=users&do=edit&id='.$u['id'].'">'.$u['login'].'</a>)';
}
$target='N/A';
switch($mod['target']){
case 'article': $target = '<a href="/index.php?view=content&do=read&id='.$mod['target_id'].'">Статья</a> (ID='.$mod['target_id'].')'; break;
case 'photo': $target = '<a href="/index.php?view=content&do=viewphoto&id='.$mod['target_id'].'">Фото</a> (ID='.$mod['target_id'].')'; break;
case 'user': $target = '<a href="/index.php?view=profile&do=view&id='.$mod['target_id'].'">Пользователь</a> (ID='.$mod['user_id'].')'; break;
}
}
}
cpAddPathway('Редактировать комментарий', '?view=components&do=config&id='.$_REQUEST['id'].'&opt=add');
echo '<h3>Редактировать комментарий</h3>';
?>
<form id="addform" name="addform" method="post" action="index.php?view=components&do=config&id=<?php echo $_REQUEST['id'];?>">
<table width="662" border="0" cellspacing="5" class="proptable">
<tr>
<td width="200"><strong>Автор комментария: </strong></td>
<td><?php echo $author?></td>
</tr>
<tr>
<td><strong>Дата подачи: </strong></td>
<td><input name="pubdate" type="text" id="title3" size="30" value="<?php echo @$mod['pubdate'];?>"/></td>
</tr>
<tr>
<td><strong>Публиковать комментарий?</strong></td>
<td><input name="published" type="radio" value="1" <?php if (@$mod['published']) { echo 'checked="checked"'; } ?> />
Да
<label>
<input name="published" type="radio" value="0" <?php if (@!$mod['published']) { echo 'checked="checked"'; } ?> />
Нет</label></td>
</tr>
</table>
<?php
$inCore->insertEditor('content', $mod['content'], '250', '100%');
?>
<p>
<label>
<input name="add_mod" type="submit" id="add_mod" value="Сохранить изменения"/>
</label>
<label>
<input name="back" type="button" id="back" value="Отмена" onclick="window.location.href='index.php?view=components';"/>
</label>
<input name="opt" type="hidden" id="do" value="update" />
<input name="item_id" type="hidden" value="<?php echo $mod['id']?>" />
</p>
</form>
<?php
}//if (add || edit)
if($opt=='config'){
if(!isset($cfg['bbcode'])) { $cfg['bbcode']=1; }
if(!isset($cfg['recode'])) { $cfg['recode']=1; }
if(!isset($cfg['min_karma'])) { $cfg['min_karma']=0; }
if(!isset($cfg['min_karma_add'])) { $cfg['min_karma_add']=0; }
if(!isset($cfg['min_karma_show'])) { $cfg['min_karma_show']=0; }
if(!isset($cfg['regcap'])) { $cfg['regcap']=1; }
if(!isset($cfg['perpage'])) { $cfg['perpage']=20; }
if(!isset($cfg['cmm_ajax'])) { $cfg['cmm_ajax']=0; }
if(!isset($cfg['cmm_ip'])) { $cfg['cmm_ip']=1; }
if(!isset($cfg['max_level'])) { $cfg['max_level']=5; }
if(!isset($cfg['edit_minutes'])) { $cfg['edit_minutes']=0; }
$GLOBALS['cp_page_head'][] = '<script type="text/javascript" src="/includes/jquery/tabs/jquery.ui.min.js"></script>';
$GLOBALS['cp_page_head'][] = '<link href="/includes/jquery/tabs/tabs.css" rel="stylesheet" type="text/css" />';
cpAddPathway('Настройки', '?view=components&do=config&id='.$_REQUEST['id'].'&opt=config');
echo '<h3>Настройки комментариев</h3>';
?>
<form action="index.php?view=components&do=config&id=<?php echo $_REQUEST['id'];?>" method="post" name="optform" target="_self" id="form1">
<div id="config_tabs" style="margin-top:12px;">
<ul id="tabs">
<li><a href="#basic"><span>Общие</span></a></li>
<li><a href="#format"><span>Формат</span></a></li>
<li><a href="#access"><span>Доступ</span></a></li>
<li><a href="#restrict"><span>Ограничения</span></a></li>
</ul>
<div id="basic">
<table width="671" border="0" cellpadding="10" cellspacing="0" class="proptable">
<tr>
<td width="316" valign="top">
<strong>E-mail для комментариев:</strong><br/>
<span class="hinttext">Оставьте пустым, если вы не хотите получать комментарии по почте</span>
</td>
<td width="313" valign="top">
<input name="email" type="text" id="email" size="30" value="<?php echo @$cfg['email'];?>"/>
</td>
</tr>
<tr>
<td valign="top">
<strong>Подписка на уведомления: </strong><br />
<span class="hinttext">Позволяет пользователям получать личные сообщения с уведомлениями о новых комментариях</span>
</td>
<td valign="top">
<input name="subscribe" type="radio" value="1" <?php if (@$cfg['subscribe']) { echo 'checked="checked"'; } ?> /> Да
<input name="subscribe" type="radio" value="0" <?php if (@!$cfg['subscribe']) { echo 'checked="checked"'; } ?> /> Нет
</td>
</tr>
</table>
</div>
<div id="format">
<table width="671" border="0" cellpadding="10" cellspacing="0" class="proptable">
<tr>
<td width="316" valign="top">
<strong>Загружать комментарии, используя ajax?</strong>
</td>
<td width="313" valign="top">
<input name="cmm_ajax" type="radio" value="1" <?php if (@$cfg['cmm_ajax']) { echo 'checked="checked"'; } ?> /> Да
<input name="cmm_ajax" type="radio" value="0" <?php if (!$cfg['cmm_ajax']) { echo 'checked="checked"'; } ?> /> Нет
</td>
</tr>
<tr>
<td valign="top"><strong>Смайлы в комментариях:</strong></td>
<td valign="top">
<input name="smiles" type="radio" value="1" <?php if (@$cfg['smiles']) { echo 'checked="checked"'; } ?> /> Да
<input name="smiles" type="radio" value="0" <?php if (@!$cfg['smiles']) { echo 'checked="checked"'; } ?> /> Нет
</td>
</tr>
<tr>
<td valign="top"><strong>BB-Code в комментариях:</strong></td>
<td valign="top">
<input name="bbcode" type="radio" value="1" <?php if (@$cfg['bbcode']) { echo 'checked="checked"'; } ?> /> Да
<input name="bbcode" type="radio" value="0" <?php if (@!$cfg['bbcode']) { echo 'checked="checked"'; } ?> /> Нет
</td>
</tr>
<tr>
<td valign="top"><strong>Текст уведомления о новых комментариях:</strong></td>
<td valign="top"><a href="/includes/letters/newcomment.txt">/includes/letters/newcomment.txt</a></td>
</tr>
<tr>
<td valign="top"><strong>Максимальный уровень вложенности:</strong></td>
<td valign="top"><input name="max_level" type="text" id="max_level" value="<?php echo @$cfg['max_level'];?>" size="3" /></td>
</tr>
<tr>
<td valign="top"><strong>Количество комментариев на странице при просмотре всех комментариев сайта:</strong></td>
<td valign="top"><input name="perpage" type="text" id="perpage" value="<?php echo @$cfg['perpage'];?>" size="3" /></td>
</tr>
<tr>
<td valign="middle"><strong>Показывать ip комментаторов администраторам: </strong></td>
<td>
<select name="cmm_ip" id="cmm_ip" style="width:220px">
<option value="0" <?php if($cfg['cmm_ip']==0) { echo 'selected'; } ?>>не показывать</option>
<option value="1" <?php if($cfg['cmm_ip']==1) { echo 'selected'; } ?>>только гостей</option>
<option value="2" <?php if($cfg['cmm_ip']==2) { echo 'selected'; } ?>>всех</option>
</select>
</td>
</tr>
<tr>
<td valign="top">
<strong>Кодировка формы добавления комментария:</strong><br />
<span class="hinttext">Переключите, если в форме "Добавить комментарий" текст отображается неправильно </span>
</td>
<td valign="top">
<select name="recode" id="recode" style="width:220px">
<option value="1" selected="selected" <?php if(@$cfg['recode']==1) { echo 'selected'; } ?>>UTF8</option>
<option value="0" <?php if(@$cfg['recode']==0) { echo 'selected'; } ?>>CP1251</option>
</select>
</td>
</tr>
</table>
</div>
<div id="access">
<table width="671" border="0" cellpadding="10" cellspacing="0" class="proptable">
<tr>
<td width="316" valign="middle"><strong>Комментарии доступны: </strong></td>
<td width="313">
<select name="canguests" id="canguests" style="width:220px">
<option value="0" <?php if(@$cfg['canguests']==0) { echo 'selected'; } ?>>Для зарегистрированных</option>
<option value="1" <?php if(@$cfg['canguests']==1) { echo 'selected'; } ?>>Для всех</option>
</select>
</td>
</tr>
<tr>
<td valign="top">
<strong>Требовать защитный код:</strong><br />
<span class="hinttext">Каким пользователям показывать капчу при добавлении комментария </span>
</td>
<td valign="top">
<select name="regcap" id="regcap" style="width:220px">
<option value="0" <?php if(@$cfg['regcap']==0) { echo 'selected'; } ?>>Для гостей</option>
<option value="1" <?php if(@$cfg['regcap']==1) { echo 'selected'; } ?>>Для всех</option>
</select>
</td>
</tr>
<tr>
<td valign="top"><strong>Публиковать сразу:</strong><br />
<span class="hinttext">Запретите, если вы хотите проверять комментарии перед добавлением на сайт</span>
</td>
<td valign="top">
<input name="publish" type="radio" value="1" <?php if (@$cfg['publish']) { echo 'checked="checked"'; } ?> /> Да
<input name="publish" type="radio" value="0" <?php if (@!$cfg['publish']) { echo 'checked="checked"'; } ?> /> Нет
</td>
</tr>
<tr>
<td valign="top"><strong>Запрещать редактирование через:</strong><br />
<span class="hinttext">Спустя указанное время после добавления комментария его редактирование станет невозможным для пользователя</span>
</td>
<td valign="top">
<select name="edit_minutes" id="regcap" style="width:220px">
<option value="0" <?php if(!$cfg['edit_minutes']) { echo 'selected'; } ?>>запрещать сразу</option>
<option value="1" <?php if(@$cfg['edit_minutes']==1) { echo 'selected'; } ?>>1 минуту</option>
<option value="5" <?php if(@$cfg['edit_minutes']==5) { echo 'selected'; } ?>>5 минут</option>
<option value="10" <?php if(@$cfg['edit_minutes']==10) { echo 'selected'; } ?>>10 минут</option>
<option value="15" <?php if(@$cfg['edit_minutes']==15) { echo 'selected'; } ?>>15 минут</option>
<option value="30" <?php if(@$cfg['edit_minutes']==30) { echo 'selected'; } ?>>30 минут</option>
<option value="60" <?php if(@$cfg['edit_minutes']==60) { echo 'selected'; } ?>>1 час</option>
</select>
</td>
</tr>
</table>
</div>
<div id="restrict">
<table width="671" border="0" cellpadding="10" cellspacing="0" class="proptable">
<tr>
<td width="316" valign="top">
<strong>Использовать ограничения:</strong><br />
<span class="hinttext">Если выключено, разрешенные пользователи смогут добавлять комментарии, независимо от значения своей кармы </span>
</td>
<td width="313" valign="top">
<input name="min_karma" type="radio" value="1" <?php if (@$cfg['min_karma']) { echo 'checked="checked"'; } ?> /> Да
<input name="min_karma" type="radio" value="0" <?php if (@!$cfg['min_karma']) { echo 'checked="checked"'; } ?>/> Нет
</td>
</tr>
<tr>
<td valign="top">
<strong>Добавление комментария:</strong><br />
<span class="hinttext">Сколько очков кармы нужно для добавления комментария </span>
</td>
<td valign="top">
<input name="min_karma_add" type="text" id="min_karma_add" value="<?php echo @$cfg['min_karma_add'];?>" size="5" />
</td>
</tr>
<tr>
<td valign="top">
<strong>Сворачивать комментарии, с рейтингом ниже:</strong><br />
<span class="hinttext">Комментарии c рейтингом ниже указанного будут выводится в свернутом виде </span>
</td>
<td valign="top">
<input name="min_karma_show" type="text" id="min_karma_show" value="<?php echo @$cfg['min_karma_show'];?>" size="5" />
</td>
</tr>
</table>
</div>
</div>
<p>
<input name="opt" type="hidden" id="do" value="saveconfig" />
<input name="save" type="submit" id="save" value="Сохранить" />
<input name="back" type="button" id="back" value="Отмена" onclick="window.location.href='index.php?view=components&do=config&id=<?php echo $_REQUEST['id']; ?>';"/>
</p>
</form>
<script type="text/javascript">$('#config_tabs > ul#tabs').tabs();</script>
<?php
}
?>