<?php
/* SocCMS
* Дата последнего редактирования 22.10.2016
* Модифицировал densnet
* Автор yadalay
*/
if (access('forum_razd_create')) {
if (isset($_POST['create'])) {
$name = $db->safesql(trim($_POST['name']));
$description = $db->safesql(trim($_POST['description']));
$number = intval($_POST['number']);
$type = (isset($_POST['type'])) ? 1 : 0;
$output = (isset($_POST['output'])) ? 1 : 0;
$icon = esc(stripcslashes(htmlspecialchars($_POST['icon'])));
$isset_name = $db->super_query("SELECT COUNT(*) as count FROM `forum_razdels` WHERE `name` = '$name' AND `id_forum` = '$forum->id'");
$isset_number = $db->super_query("SELECT COUNT(*) as count FROM `forum_razdels` WHERE `number` = '$number' AND `id_forum` = '$forum->id'");
if (preg_match("/[^(\w)|(\x7F-\xFF)|(\s)|(\.\-)]/", $_POST['name'], $m)) {
$_SESSION['err'] = lang('В поле Название раздела присутствуют запрещенные') . " <span style='font-weight: bold; color: red;'>$m[0]</span> " . lang('символы');
} else
if (mb_strlen($name) < $set['razdel_name_min'] || mb_strlen($name) > $set['razdel_name_max']) {
$_SESSION['err'] = lang('В поле Название раздела можно использовать от') . " $set[razdel_name_min] " . lang('до') . " $set[razdel_name_max] " . lang('символов');
} elseif ($number < 0 || $number == NULL || $number == 0) {
$_SESSION['err'] = lang('Введите уровень');
} elseif (mb_strlen($description) > $set['razdel_opis_max']) {
$_SESSION['err'] = lang('Слишком длинное описание раздела');
} elseif ($isset_number['count'] > 0) {
$_SESSION['err'] = lang('Данный уровень уже использует другой раздел этого подфорума');
} elseif ($isset_name['count'] > 0) {
$_SESSION['err'] = lang('Раздел с таким названием уже существует в этом подфоруме');
} else {
admin_log('Форум', 'Разделы', "Создание раздела $name в подфоруме $forum->name");
$db->query("INSERT INTO forum_razdels SET id_forum = '$forum->id', name = '$name', description = '$description', icon = '$icon', number = '$number', type = '$type', output = '$output'");
$_SESSION['message'] = lang('Раздел успешно создан');
header('Location: ' . DIR_FORUM . $forum->id . '/');
exit;
}
}
$next_number = $db->super_query("SELECT MAX(`number`) as number FROM `forum_razdels` WHERE `id_forum` = '$forum->id'");
$next_number = $next_number['number'] + 1;
#Навигация
echo "<div class='list-group-item-null list-group-item-grey'><small>";
echo "<a href='/' class='hint--right' data-hint='" . lang('На главную') . "'><i class='fa fa-home fa-lg'></i></a> <i class='fa fa-angle-right fa-fw'></i> ";
echo "<a href='" . DIR_FORUM . "'>" . lang('Форум') . "</a> <i class='fa fa-angle-right fa-fw'></i> ";
echo "<a href='" . DIR_FORUM . "$forum->id/'>" . toOutput($forum->name, 1, 1, 0, 0, 0) . "</a> <i class='fa fa-angle-right fa-fw'></i> ";
echo lang('Создание раздела');
echo "</small></div>";
echo "<form action='" . DIR_FORUM . "$forum->id/create_razdel.html' class='list-group-item-null-mini' method='post'>";
$doc->Input('name', 'Название раздела', null, null, 'form-control', 'text', 'required');
$doc->Textarea('description', 'Описание раздела');
$doc->Input('icon', 'Иконка', null, "folder");
$doc->Input('number', 'Позиция', null, "$next_number", 'form-control', 'number');
echo lang('Могут создавать темы только') . ":<br />";
$doc->Checkbox('type', 'Администраторы + модераторы', '1');
echo "<div class='hr'></div>";
echo lang('Вывод раздела') . ":<br />";
$doc->Checkbox('output', 'Отображать посл. 3 темы', '1');
echo "<br />";
$doc->Button('btn btn-primary btn-sm', 'create', null, 'Создать');
$doc->a("" . DIR_FORUM . "$forum->id/", 'btn btn-secondary btn-sm', null, 'Отменить');
echo "</form>";
require_once H . 'sys/inc/tfoot.php';
} else {
header('Location: ' . DIR_FORUM . $forum->id . '/');
}
exit;