Вход Регистрация
Файл: forum/includes/edittopic.php
Строк: 181
<?php
# Script by seg0ro http://mobilarts.ru
# Not for sale!!!



$set['title'] .= ' | Редактирование';
include 
'engine/includes/head.php';

if (!
$topic){
  
Core::msg_show('Отсутствует идентификатор темы!<br /><a href="index.php">Форум</a>');
  include 
'engine/includes/foot.php';
 }
  
$curator = array();

if (isset(
$topicRes['curator']))
{
  
$curator $sql->query("SELECT `id`, `nick`, `date_reg`, `date_last`, `pol` FROM `user` WHERE `id` = '".$topicRes['curator']."' LIMIT 1 ")->fetch();
}

if (!
$moder && !$curator){
  
Core::msg_show('У вас недостаточно прав для просмотра этой страницы!<br /><a href="index.php">Форум</a>');
  include 
'engine/includes/foot.php';
  
}

$name = isset($_POST['name']) ? trim($_POST['name']) : $topicRes['name'];
$pollName = isset($_POST['poll_name']) ? trim($_POST['poll_name']) : $topicRes['poll_name'];

echo 
'<div class="fmenu"><a href="index.php">Форум</a>  /  <a href="index.php?topic='.$topicRes['id'].'&amp;page=1">'.text::output($topicRes['name']).'</a>  /  Изменить тему</div>';


if (isset(
$_POST['send'])){
  if (empty(
$name))
    
$error .= 'Не введено название!<br />';

  if (!isset(
$error)){

    if (
$topicRes['close'] == && Core::form('close') == 1)
    {
        
$sql->query("INSERT INTO `forum_posts` SET
            `refid` = '
$topic',
            `time` = '"
.time()."',
            `user_id` = '"
.$user_id."',
            `user` = 'null',
            `text` = 'Тема закрыта модератором [b]"
.$user['nick']."[/b]',
            `files` = '0'"
);
            
$pid mysqli_insert_id($sql->db);
      
       if (
$topicRes['user_id'] != $user_id)
            
journal_add($topicRes['user_id'], 'Ваша тема <a href="index.php?post='.$pid.'">'.$topicRes['name'].'</a> закрыта');
      
      
$sql->query("UPDATE `forum_topics` SET
      `time` = '"
.time()."',
      `lastpost` = '
$user[nick]:|:$pid',
      `count` = count + 1 WHERE `id` = '
$topic' LIMIT 1 ");
      
      
$sql->query("UPDATE `forum_forums` SET `last_topic` = '$topic:|:$name:|:".time()."' WHERE `id` = '".$topicRes['refid']."' LIMIT 1 ");
    }
  
    
$sql->query("UPDATE `forum_topics` SET
    `name` = '"
.my_esc($name)."',
    `close` = '"
.(isset($_POST['close']) ? 0)."',
    `sticky` = '"
.(isset($_POST['sticky']) ? 0)."',
    `clip` = '"
.(isset($_POST['clip']) ? 0)."'
    WHERE `id` = '
$topic'
    "
);
    
    if (
$topicRes['name'] != $name){
      
$sql->query("INSERT INTO `forum_posts` SET
      `refid` = '
$topic',
      `time` = '"
.time()."',
      `user_id` = '"
.$user_id."',
      `user` = 'Система',
      `text` = 'Тема переименована (cтарое название [b]"
.$topicRes['name']."[/b])',
      `files` = '0'"
);
      
$pid mysqli_insert_id($sql->db);
      
      if (
$topicRes['user_id'] != $user_id)
        
journal_add($topicRes['user_id'], 'Ваша <a href="index.php?post='.$pid.'">тема</a> переименована (cтарое название <strong>'.$topicRes['name'].'</strong>)');
      
      
$sql->query("UPDATE `forum_topics` SET
      `time` = '"
.time()."',
      `lastpost` = '
$user[nick]:|:$pid',
      `count` = count + 1 WHERE `id` = '
$topic' LIMIT 1 ");
      
      
$sql->query("UPDATE `forum_forums` SET `last_topic` = '$topic:|:$name:|:".time()."' WHERE `id` = '".$topicRes['refid']."' LIMIT 1 ");

    }
        
    if (
$moder){
      
$user2 $sql->query("SELECT `id`, `group_access` FROM `user` WHERE `id` = '".intval($_POST['curator'])."' LIMIT 1 ")->fetch();
        
$sql->query("UPDATE `forum_topics` SET `curator` = '".intval($_POST['curator'])."' WHERE `id` = '$topic' ");
    }
    
    
header ('Refresh:1; URL=index.php?topic='.$topic.'&page=end');
    echo 
'<div class="post">Тема изменена<br /><a href="index.php?topic='.$topic.'&amp;page=end">Далее</a></div>';
    include 
'engine/includes/foot.php';
    
  }
}

if (isset(
$_GET['closepoll'])){
  
$pollSet = array('poll_mod' => $pollSet['poll_mod'], 'total_polls' => $pollSet['total_polls'], 'total_polled' => $pollSet['total_polled'], 'poll_close' => 1);
  
$sql->query("UPDATE `forum_topics` SET
  `poll_set` = '"
.serialize($pollSet)."'
  WHERE `id`='
$topic'
  "
);
  
$pollSet['poll_close'] = 1;
}

if (isset(
$_GET['openpoll'])){
  
$pollSet = array('poll_mod' => $pollSet['poll_mod'], 'total_polls' => $pollSet['total_polls'], 'total_polled' => $pollSet['total_polled'], 'poll_close' => 0);
  
$sql->query("UPDATE `forum_topics` SET
  `poll_set` = '"
.serialize($pollSet)."'
  WHERE `id` = '
$topic'
  "
);
  
$pollSet['poll_close'] = 0;
}

if (isset(
$_POST['poll'])){
  if (empty(
$_POST['poll_name']))
    
$error .= 'Вы не ввели имя голосования!<br />';
    
  if (!
$topicRes['poll_name'] && (empty($_POST[0]) || empty($_POST[1])))
    
$error .= 'Не введены как минимум два варианта голосования!<br />';
  
  if (empty(
$error)){
    if (
$topicRes['poll_name']){
      
$pollSet = array('poll_mod' => $pollSet['poll_mod'], 'total_polls' => $pollSet['total_polls'], 'total_polled' => $pollSet['total_polled'], 'poll_close' => $pollSet['poll_close']);
      
$sql->query("UPDATE `forum_topics` SET
      `poll_name` = '
$pollName',
      `poll_set` = '"
.serialize($pollSet)."'
      WHERE `id` = '
$topic'
      "
);
      while (
$pollRes $sql->fetch($pollReq)){
        if (!empty (
$_POST[$pollRes['id']])){
          
$text mb_substr(trim($_POST[$pollRes['id']]), 0100);
          
$sql->query("UPDATE `forum_polls` SET
          `name` = '"
.my_esc($text)."'
          WHERE `id` = '"
.$pollRes['id']."'
          "
);
        }
      }
      
      
header ('Refresh:1; URL=index.php?topic='.$topic.'&page=end');
      echo 
'<div class="msg">Голосование изменено<br /><a href="index.php?topic='.$topic.'&amp;page=end">Далее</a></div>';
      include 
'engine/includes/foot.php';
      
    }else{
      
$polName mb_substr($pollName0200);
      
$pollSet = array('poll_mod' => intval($_POST['poll_mod']), 'total_polls' => 0'total_polled' => 0'poll_close' => 0);
      
$sql->query("UPDATE `forum_topics` SET
      `poll_name` = '"
.my_esc($pollName)."',
      `poll_set` = '"
.serialize($pollSet)."'
      WHERE `id` = '
$topic'
      "
);
        
      if (
$_POST['count_vars'] > 20)
        
$_POST['count_vars'] = 20;
      elseif (
$_POST['count_vars'] < 2)
        
$_POST['count_vars'] = 2;
      for (
$var 0$var $_POST['count_vars']; $var++){
        
$vars mb_substr(trim($_POST[$var]), 0100);
        if (empty(
$vars)){
          continue;
        }
        
$sql->query("INSERT INTO `forum_polls` SET
        `refid` = '
$topic',
        `name` = '"
.my_esc($vars)."'
        "
);
      }
      
header ('Refresh:1; URL=index.php?topic='.$topic.'&page='.$cur_page);
      echo 
'<div class="msg">Голосование создано<br /><a href="index.php?topic='.$topic.'&amp;page='.$cur_page.'">Далее</a></div>';
      include 
'engine/includes/foot.php';
      
    }
  }
}

if (isset(
$error))
  echo 
Core::msg_show($error);

echo 
'<form id="form" action="index.php?act=edittopic&amp;topic='.$topic.'&amp;page=1" method="post">';
echo 
'<div class="p_m">Название <img style="cursor: pointer;" onclick="alert(this.title);" src="images/question.png" alt="?" title="Максимально 100 символов" />:<br /><input type="text" name="name" value="'.text($name).'" /></div>';
echo 
'<div class="error">';
echo 
'<label><input type="checkbox" '.($topicRes['clip'] ? 'checked="checked" ' '').'name="clip" value="1" />&nbsp;Закрепить 1-й пост</label><br />';
echo 
'<label><input type="checkbox" '.($topicRes['close'] ? 'checked="checked" ' '').'name="close" value="1" />&nbsp;Закрыть</label><br />';
echo 
'<label><input type="checkbox" '.($topicRes['sticky'] ? 'checked="checked" ' '').'name="sticky" value="1" />&nbsp;Закрепить</label><br />';
  
if (
$moder)
  echo 
'ID куратора: <input type="text" size="5" name="curator" value="'.$topicRes['curator'].'" /><br />';
  
echo 
'<input type="submit" name="send" value="Сохранить" /></div>';

if (
$topicRes['poll_name']){
  echo 
'<div class="fmenu">Голосование <a href="index.php?act=delpoll&amp;topic='.$topic.'">удалить</a> <a href="index.php?act=edittopic&amp;topic='.$topic.'&amp;page=1&amp;'.($pollSet['poll_close'] ? 'openpoll">открыть' 'closepoll">закрыть').'</a></div>';
  echo 
'<div class="p_m">Название <img style="cursor: pointer;" onclick="alert(this.title);" src="images/question.png" alt="?" title="Максимально 200 символов" />:<br /><input type="text" name="poll_name" value="'.text($pollName).'" /><br />';
  while (
$pollRes $sql->fetch($pollReq)){
    echo 
'Вариант '.($i 1).' <img style="cursor: pointer;" onclick="alert(this.title);" src="images/question.png" alt="?" title="Максимально 100 символов" />:<br /><input type="text" name="'.$pollRes['id'].'" value="'.text($pollRes['name']).'" /><br />';          
    ++
$i;
  }
}else{
  echo 
'<div class="fmenu">Голосование</div>';
  echo 
'<div class="p_m">Название <img style="cursor: pointer;" onclick="alert(this.title);" src="images/question.png" alt="?" title="Максимально 200 символов" />:<br /><input type="text" name="poll_name" value="'.(isset($_POST['poll_name']) ? htmlspecialchars($_POST['poll_name']) : null).'" /><br />';

  if (isset(
$_POST['add']))
    ++
$_POST['count_vars'];
  elseif (isset(
$_POST['del']))
    --
$_POST['count_vars'];
  if (empty(
$_POST['count_vars']) || $_POST['count_vars'] < 2)
    
$_POST['count_vars'] = 2;
  elseif (
$_POST['count_vars'] > 20)
    
$_POST['count_vars'] = 20;
  for (
$vars 0$vars $_POST['count_vars']; $vars++){
    echo 
'Вариант '.($vars 1).' <img style="cursor: pointer;" onclick="alert(this.title);" src="images/question.png" alt="?" title="Максимально 100 символов" />:<br /><input type="text" name="'.$vars.'" value="'.(isset($_POST[$vars]) ? htmlspecialchars($_POST[$vars]) : null).'" /><br />';
  }
  echo 
'<input type="hidden" name="count_vars" value="'.intval($_POST['count_vars']).'" />';
  echo 
$_POST['count_vars'] < 20 '<br /><input type="submit" name="add" value=" + " />' '';
  echo 
$_POST['count_vars'] > '<input type="submit" name="del" value=" - " /><br />' '<br />';
  echo 
'<label><input type="radio" value="0" name="poll_mod" '.(isset($_POST['poll_mod']) ? 'checked="checked" ' '').'/> Можно выбирать только один вариант</label><br />
<label><input type="radio" value="1" name="poll_mod" '
.(isset($_POST['poll_mod']) ? 'checked="checked" ' '').'/> Можно выбирать несколько вариантов</label><br />';
}

echo 
'<input type="submit" name="poll" value="Сохранить" /></div></form>';
Онлайн: 1
Реклама