Вход Регистрация
Файл: admin/components/comments/backend.php
Строк: 415
<?php
if(!defined('VALID_CMS_ADMIN')) { die('ACCESS DENIED'); }
/******************************************************************************/
//                                                                            //
//                             InstantCMS v1.10                               //
//                        http://www.instantcms.ru/                           //
//                                                                            //
//                   written by InstantCMS Team, 2007-2012                    //
//                produced by InstantSoft, (www.instantsoft.ru)               //
//                                                                            //
//                        LICENSED BY GNU/GPL v2                              //
//                                                                            //
/******************************************************************************/

function cpStripComment($text){

    
$text strip_tags($text);

    if (
sizeof($text) < 120) { return $text; }

    return 
mb_substr($text0120) . '...';

}

$opt cmsCore::request('opt''str''list');
$id  cmsCore::request('id''int'0);

cpAddPathway('Комментарии пользователей''?view=components&do=config&id='.$id);

$toolmenu[1]['icon'] = 'listcomments.gif';
$toolmenu[1]['title'] = 'Все комментарии';
$toolmenu[1]['link'] = '?view=components&do=config&id='.$id.'&opt=list';

$toolmenu[2]['icon'] = 'config.gif';
$toolmenu[2]['title'] = 'Настройки компонента';
$toolmenu[2]['link'] = '?view=components&do=config&id='.$id.'&opt=config';

cpToolMenu($toolmenu);

cmsCore::loadModel('comments');
$model = new cms_model_comments();

$cfg $model->config;

if (
$opt=='saveconfig'){

    if (!
cmsCore::validateForm()) { cmsCore::error404(); }

    
$cfg['email']          = cmsCore::request('email''email''');
    
$cfg['regcap']         = cmsCore::request('regcap''int');
    
$cfg['subscribe']      = cmsCore::request('subscribe''int');
    
$cfg['min_karma']        = cmsCore::request('min_karma''int');
    
$cfg['min_karma_show'] = cmsCore::request('min_karma_show''int');
    
$cfg['min_karma_add']  = cmsCore::request('min_karma_add''int');
    
$cfg['perpage']        = cmsCore::request('perpage''int');
    
$cfg['cmm_ajax']        = cmsCore::request('cmm_ajax''int');
    
$cfg['cmm_ip']            = cmsCore::request('cmm_ip''int');
    
$cfg['max_level']        = cmsCore::request('max_level''int');
    
$cfg['edit_minutes']   = cmsCore::request('edit_minutes''int');
    
$cfg['watermark']        = cmsCore::request('watermark''int');

    
$inCore->saveComponentConfig('comments'$cfg);

    
cmsCore::addSessionMessage('Настройки успешно сохранены''success');

    
cmsUser::clearCsrfToken();

    
cmsCore::redirectBack();

}

if (
$opt == 'show_comment'){
    if(isset(
$_REQUEST['item_id'])) {
        
$item_id cmsCore::request('item_id''int');
        
$sql "UPDATE cms_comments SET published = 1 WHERE id = $item_id";
        
$inDB->query($sql) ;
        echo 
'1'; exit;
    }
}

if (
$opt == 'hide_comment'){
    if(isset(
$_REQUEST['item_id'])) {
        
$item_id cmsCore::request('item_id''int');
        
$sql "UPDATE cms_comments SET published = 0 WHERE id = $item_id";
        
$inDB->query($sql) ;
        echo 
'1'; exit;
    }
}

if (
$opt == 'update'){

    if (!
cmsCore::validateForm()) { cmsCore::error404(); }

    if(isset(
$_REQUEST['item_id'])) {

        
$item_id cmsCore::request('item_id''int');

        
$guestname cmsCore::request('guestname''str''');
        
$pubdate   cmsCore::request('pubdate''str');
        
$published cmsCore::request('published''int');
        
$content   cmsCore::request('content''html');
        
$content   $inDB->escape_string($content);

        
$sql "UPDATE cms_comments
                SET guestname = '
$guestname',
                    pubdate = '
$pubdate',
                    published=
$published,
                    content='
$content'
                WHERE id = 
$item_id
                LIMIT 1"
;
        
$inDB->query($sql) ;

        
cmsUser::clearCsrfToken();

        
cmsCore::redirect('index.php?view=components&do=config&id='.$id.'&opt=list');

    }

}

if(
$opt == 'delete'){
    if(isset(
$_REQUEST['item_id'])) {

        
$model->deleteComment(cmsCore::request('item_id''int'));
        
cmsCore::redirect('index.php?view=components&do=config&id='.$id.'&opt=list');
    }
}

if (
$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='.$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='.$id.'&opt=delete&item_id=%id%';

    
//Print table
    
cpListTable('cms_comments'$fields$actions'''pubdate DESC');
}

if(
$opt=='edit'){

    
$mod $model->getComment(cmsCore::request('item_id''int'));
    if(!
$mod) { cmsCore::error404(); }

    if(
$mod['user_id']==0) { $author '<input name="guestname" type="text" id="title" size="30" value="'.$mod['guestname'].'"/>'; }
    else {
        
$author $mod['nickname'].' (<a target="_blank" href="/admin/index.php?view=users&do=edit&id='.$mod['user_id'].'">'.$mod['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='.$id.'&opt=edit&item_id='.$mod['id']);
    echo 
'<h3>Редактировать комментарий</h3>';

?>

<form id="addform" name="addform" method="post" action="index.php?view=components&do=config&id=<?php echo $id;?>">
<input type="hidden" name="csrf_token" value="<?php echo cmsUser::getCsrfToken(); ?>" />
    <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><label><input name="published" type="radio" value="1" <?php if ($mod['published']) { echo 'checked="checked"'; } ?> /> Да </label>
          <label> <input name="published" type="radio" value="0"  <?php if (!$mod['published']) { echo 'checked="checked"'; } ?> /> Нет </label></td>
      </tr>
    </table>
        <?php cmsCore::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'){

    
$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='.$id.'&opt=config');
    echo 
'<h3>Настройки комментариев</h3>';

?>

<form action="index.php?view=components&do=config&id=<?php echo $id;?>" method="post" name="optform" target="_self" id="form1">
<input type="hidden" name="csrf_token" value="<?php echo cmsUser::getCsrfToken(); ?>" />
<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">
                    <label><input name="subscribe" type="radio" value="1" <?php if ($cfg['subscribe']) { echo 'checked="checked"'; } ?> /> Да</label>
                    <label><input name="subscribe" type="radio" value="0"  <?php if (!$cfg['subscribe']) { echo 'checked="checked"'; } ?> /> Нет</label>
                </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">
                    <label><input name="cmm_ajax" type="radio" value="1" <?php if ($cfg['cmm_ajax']) { echo 'checked="checked"'; } ?> /> Да</label>
                    <label><input name="cmm_ajax" type="radio" value="0"  <?php if (!$cfg['cmm_ajax']) { echo 'checked="checked"'; } ?> /> Нет</label>
                </td>
            </tr>
            <tr>
                <td valign="top"><strong>Водяной знак для фотографий</strong></td>
                <td valign="top">
                    <label><input name="watermark" type="radio" value="1" <?php if ($cfg['watermark']) { echo 'checked="checked"'; } ?> /> Да</label>
                    <label><input name="watermark" type="radio" value="0"  <?php if (!$cfg['watermark']) { echo 'checked="checked"'; } ?> /> Нет</label>
                </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>
        </table>
    </div>

    <div id="access">
        <table width="671" border="0" cellpadding="10" cellspacing="0" class="proptable">
            <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">
                    <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">
                    <label><input name="min_karma" type="radio" value="1" <?php if ($cfg['min_karma']) { echo 'checked="checked"'; } ?> /> Да</label>
                    <label><input name="min_karma" type="radio" value="0" <?php if (!$cfg['min_karma']) { echo 'checked="checked"'; } ?>/> Нет</label>
                </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 $id?>';"/>
</p>
</form>

<script type="text/javascript">$('#config_tabs > ul#tabs').tabs();</script>

<?php
    
}
?>
Онлайн: 0
Реклама