Файл: forum/action/create_razdel.php
Строк: 88
<?php
if (user_access('forum_razd_create')) {
if (isset($_POST['create'])) {
$name = trim($_POST['name']);
$description = trim($_POST['description']);
$number = intval($_POST['number']);
$type = (isset($_POST['type'])) ? 1 : 0;
$output = (isset($_POST['output'])) ? 1 : 0;
$isset_name = $db->query('SELECT COUNT(*) FROM `forum_razdels` WHERE `name` = ? AND `id_forum` = ?i', [$name, $forum->id])->el();
$isset_number = $db->query('SELECT COUNT(*) FROM `forum_razdels` WHERE `number` = ?i AND `id_forum` = ?i', [$number, $forum->id])->el();
if (preg_match("/[^(w)|(x7F-xFF)|(s)|(.-)]/", $_POST['name'], $m)) {
?>
<div class = 'err'>
В поле «Название раздела» присутствуют запрещенные <span style="font-weight: bold; color: red;"><?php echo $m[0]?></span> символы!.
</div>
<?php
} elseif (mb_strlen($name) < $set['forum_new_them_name_min_pod'] || mb_strlen($name) > $set['forum_new_them_name_max_pod']) {
?>
<div class = 'err'>В поле «Название раздела» можно использовать от <?php echo $set['forum_new_them_name_min_pod'] ?> до <?php echo $set['forum_new_them_name_max_pod'] ?> символов.</div>
<?php
} elseif ($number < 0 || $number == null || $number == 0) {
?>
<div class = 'err'>Введите уровень.</div>
<?php
} elseif (mb_strlen($description) > $set['forum_new_them_name_max_pod_opis']) {
?>
<div class = 'err'>Слишком длинное описание раздела.</div>
<?php
} elseif ($isset_number > 0) {
?>
<div class = 'err'>Данный уровень уже использует другой раздел этого подфорума.</div>
<?php
} elseif ($isset_name > 0) {
?>
<div class = 'err'>Раздел с таким названием уже существует в этом подфоруме.</div>
<?php
} else {
admin_log('Форум', 'Разделы', 'Создание раздела "'.$name.'" в подфоруме "'.$forum->name.'".');
$data = [$forum->id, $name, $description, $number, $type, $output];
$db->query('INSERT INTO `forum_razdels` (`id_forum`, `name`, `description`, `number`, `type`, `output`) VALUES ( ?i, ?, ?, ?i, ?, ?)', $data);
$_SESSION['msg'] = '<div class = "msg">Раздел успешно создан.</div>';
header('Location: '.FORUM.'/'.$forum->id.'/');
exit;
}
} elseif (isset($_POST['cancel'])) {
header('Location: '.FORUM.'/'.$forum->id.'/');
exit;
}
$next_number = $db->query('SELECT MAX(`number`) FROM `forum_razdels` WHERE `id_forum` = '.$forum->id)->el() + 1; ?>
<div class = 'menu_razd' style = 'text-align: left'>
<a href = '<?php echo FORUM ?>'>Форум</a> / <a href = '<?php echo FORUM.'/'.$forum->id ?>/'><?php echo output_text($forum->name, 1, 1, 0, 0, 0) ?></a> / Создание раздела
</div>
<form action = '<?php echo FORUM.'/'.$forum->id ?>/create_razdel.html' method = 'post' class="p_m">
<b>Название раздела (<?php echo $set['forum_new_them_name_max_pod'] ?> символ(а/ов)):</b><br />
<input type = 'text' name = 'name' value = '' /><br /><br />
<b>Описание раздела (<?php echo $set['forum_new_them_name_max_pod_opis'] ?> символ(а/ов)):</b><br />
<textarea name = 'description'></textarea><br /><br />
<b>Позиция:</b> <input type = 'text' name = 'number' value = '<?php echo $next_number ?>' size = '3' /><br />
<br /><b>Могут создавать темы только:</b><br />
<label><input type = 'checkbox' name = 'type' value = '1' /> Администраторы + модераторы</label><br />
<br /><b>Вывод раздела:</b><br />
<label><input type = 'checkbox' name = 'output' value = '1' /> Отображать посл. 3 темы вместо описания</label><br /><br />
<input type = 'submit' name = 'create' value = 'Создать' /> <input type = 'submit' name = 'cancel' value = 'Отменить' />
</form>
<?php
include_once '../sys/inc/tfoot.php';
} else {
header('Location: '.FORUM.'/'.$forum->id.'/');
}
exit;
?>