mirror of https://github.com/avecms/AVE.cms.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2582 lines
67 KiB
2582 lines
67 KiB
<?php |
|
|
|
/** |
|
* AVE.cms |
|
* |
|
* @package AVE.cms |
|
* @version 3.x |
|
* @filesource |
|
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru |
|
* |
|
*/ |
|
|
|
/** |
|
* Класс работы с рубриками |
|
*/ |
|
class AVE_Rubric |
|
{ |
|
/** |
|
* Количество рубрик на странице |
|
* |
|
* @public int |
|
*/ |
|
public $_limit = 30; |
|
|
|
|
|
function get_rubric_fields_group($rubric_id) |
|
{ |
|
|
|
global $AVE_DB, $AVE_Template; |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
* |
|
FROM |
|
" . PREFIX . "_rubric_fields_group |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
ORDER BY |
|
group_position ASC |
|
"); |
|
|
|
$groups = array(); |
|
|
|
while($row = $sql->FetchRow()) |
|
{ |
|
array_push($groups, $row); |
|
} |
|
|
|
return $groups; |
|
} |
|
|
|
|
|
/** |
|
* Вывод списка рубрик |
|
* |
|
*/ |
|
function rubricList() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$rubrics = array(); |
|
$num = $AVE_DB->Query("SELECT COUNT(*) FROM " . PREFIX . "_rubrics")->GetCell(); |
|
|
|
$page_limit = $this->_limit; |
|
$pages = ceil($num / $page_limit); |
|
$set_start = get_current_page() * $page_limit - $page_limit; |
|
|
|
if ($num > $page_limit) |
|
{ |
|
$page_nav = " <a class=\"pnav\" href=\"index.php?do=rubs&page={s}&cp=" . SESSION . "\">{t}</a> "; |
|
$page_nav = get_pagination($pages, 'page', $page_nav); |
|
$AVE_Template->assign('page_nav', $page_nav); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rub.*, |
|
(SELECT 1 FROM " . PREFIX . "_documents WHERE rubric_id = rub.Id LIMIT 1) AS doc_count, |
|
(SELECT count(*) FROM " . PREFIX . "_rubric_fields AS fld WHERE fld.rubric_id = rub.Id) AS fld_count, |
|
(SELECT count(*) FROM " . PREFIX . "_rubric_templates AS tmpls WHERE tmpls.rubric_id = rub.Id) AS tmpls_count |
|
FROM |
|
" . PREFIX . "_rubrics AS rub |
|
GROUP BY rub.Id |
|
ORDER BY rub.rubric_position |
|
LIMIT " . $set_start . "," . $page_limit |
|
); |
|
|
|
while ($row = $sql->FetchRow()) |
|
array_push($rubrics, $row); |
|
|
|
$AVE_Template->assign('rubrics', $rubrics); |
|
} |
|
|
|
/** |
|
* создание рубрики |
|
* |
|
*/ |
|
function rubricNew() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
switch ($_REQUEST['sub']) |
|
{ |
|
case '': |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/rubnew.tpl')); |
|
break; |
|
|
|
case 'save': |
|
$errors = array(); |
|
|
|
if (empty($_POST['rubric_title'])) |
|
{ |
|
array_push($errors, $AVE_Template->get_config_vars('RUBRIK_NO_NAME')); |
|
} |
|
else |
|
{ |
|
$name_exist = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
rubric_title = '" . $_POST['rubric_title'] . "' |
|
LIMIT 1 |
|
")->NumRows(); |
|
|
|
if ($name_exist) array_push($errors, $AVE_Template->get_config_vars('RUBRIK_NAME_EXIST')); |
|
|
|
if (! empty($_POST['rubric_alias'])) |
|
{ |
|
if (preg_match(TRANSLIT_URL ? '/[^\%HYa-z0-9\/_-]+/' : '/[^\%HYa-zа-яА-Яёїєі0-9\/_-]+/u', $_POST['rubric_alias'])) |
|
{ |
|
array_push($errors, $AVE_Template->get_config_vars('RUBRIK_PREFIX_BAD_CHAR')); |
|
} |
|
else |
|
{ |
|
$prefix_exist = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
rubric_alias = '" . $_POST['rubric_alias'] . "' |
|
LIMIT 1 |
|
")->NumRows(); |
|
|
|
if ($prefix_exist) array_push($errors, $AVE_Template->get_config_vars('RUBRIK_PREFIX_EXIST')); |
|
} |
|
} |
|
|
|
if (!empty($errors)) |
|
{ |
|
$AVE_Template->assign('errors', $errors); |
|
$AVE_Template->assign('templates', get_all_templates()); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/rubnew.tpl')); |
|
} |
|
else |
|
{ |
|
$position = (int)$AVE_DB->Query(" |
|
SELECT |
|
MAX(rubric_position) |
|
FROM |
|
" . PREFIX . "_rubrics |
|
")->GetCell() + 1; |
|
|
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_title = '" . $_POST['rubric_title'] . "', |
|
rubric_alias = '" . $_POST['rubric_alias'] . "', |
|
rubric_template_id = '" . intval($_POST['rubric_template_id']) . "', |
|
rubric_author_id = '" . $_SESSION['user_id'] . "', |
|
rubric_created = '" . time() . "', |
|
rubric_position = '" . $position . "', |
|
rubric_changed = '" . time() . "', |
|
rubric_changed_fields = '" . time() . "' |
|
"); |
|
|
|
$iid = $AVE_DB->InsertId(); |
|
|
|
// Выставляем всем право на просмотр рубрики, админу - все права |
|
$sql_user = $AVE_DB->Query(" |
|
SELECT |
|
grp.*, |
|
COUNT(usr.Id) AS UserCount |
|
FROM |
|
" . PREFIX . "_user_groups AS grp |
|
LEFT JOIN |
|
" . PREFIX . "_users AS usr |
|
ON usr.user_group = grp.user_group |
|
GROUP BY grp.user_group |
|
"); |
|
while ($row = $sql_user->FetchRow()) |
|
{ |
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubric_permissions |
|
SET |
|
rubric_id = '" . $iid . "', |
|
user_group_id = '" . $row->user_group . "', |
|
rubric_permission = '". (($row->user_group == 1) ? "alles|docread|new|newnow|editown|editall|delrev" : "docread")."' |
|
"); |
|
} |
|
|
|
// Сохраняем системное сообщение в журнал |
|
reportLog($AVE_Template->get_config_vars('RUBRIK_LOG_NEW_RUBRIC') . ' - ' . stripslashes(htmlspecialchars($_POST['rubric_title'], ENT_QUOTES)) . ' (id: '.$iid.')'); |
|
|
|
header('Location:index.php?do=rubs&action=edit&Id=' . $iid . '&cp=' . SESSION); |
|
exit; |
|
} |
|
} |
|
break; |
|
} |
|
} |
|
|
|
|
|
/** |
|
* Запись настроек рубрики |
|
* |
|
*/ |
|
function quickSave() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
if (check_permission_acp('rubric_edit')) |
|
{ |
|
foreach ($_POST['rubric_title'] as $rubric_id => $rubric_title) |
|
{ |
|
if (! empty($rubric_title)) |
|
{ |
|
$set_rubric_title = ''; |
|
$set_rubric_alias = ''; |
|
|
|
$name_exist = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
rubric_title = '" . $rubric_title . "' |
|
AND |
|
Id != '" . $rubric_id . "' |
|
LIMIT 1 |
|
")->NumRows(); |
|
|
|
if (!$name_exist) |
|
{ |
|
$set_rubric_title = "rubric_title = '" . $rubric_title . "',"; |
|
} |
|
|
|
if (isset($_POST['rubric_alias'][$rubric_id]) && $_POST['rubric_alias'][$rubric_id] != '') |
|
{ |
|
$pattern = TRANSLIT_URL ? '/[^\%HYa-z0-9\/_-]+/' : '/[^\%HYa-zа-яА-Яёїєі0-9\/_-]+/u'; |
|
|
|
if (! (preg_match($pattern, $_POST['rubric_alias'][$rubric_id]))) |
|
{ |
|
$prefix_exist = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
rubric_alias = '" . $_POST['rubric_alias'][$rubric_id] . "' |
|
AND |
|
Id != '" . $rubric_id . "' |
|
LIMIT 1 |
|
")->NumRows(); |
|
|
|
if (! $prefix_exist) |
|
{ |
|
$set_rubric_alias = "rubric_alias = '" . trim(preg_replace($pattern, '', $_POST['rubric_alias'][$rubric_id]), '/') . "',"; |
|
} |
|
} |
|
} |
|
else |
|
{ |
|
$set_rubric_alias = "rubric_alias = '',"; |
|
} |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
" . $set_rubric_title . " |
|
" . $set_rubric_alias . " |
|
rubric_meta_gen = '" . (isset($_POST['rubric_meta_gen'][$rubric_id]) ? $_POST['rubric_meta_gen'][$rubric_id] : '0') . "', |
|
rubric_alias_history = '" . (isset($_POST['rubric_alias_history'][$rubric_id]) ? $_POST['rubric_alias_history'][$rubric_id] : '0') . "', |
|
rubric_template_id = '" . (int)$_POST['rubric_template_id'][$rubric_id] . "', |
|
rubric_docs_active = '" . (isset($_POST['rubric_docs_active'][$rubric_id]) ? $_POST['rubric_docs_active'][$rubric_id] : '0') . "', |
|
rubric_changed = '".time()."', |
|
rubric_changed_fields = '".time()."' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
} |
|
} |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
$message = $AVE_Template->get_config_vars('RUBRIK_REP_QUICKSAVE_T'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_REP_QUICKSAVE_H'); |
|
$theme = 'accept'; |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_QUICKSAVE')); |
|
|
|
if (isset($_REQUEST['ajax']) && $_REQUEST['ajax'] = 'run') |
|
{ |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
else |
|
{ |
|
$page = !empty($_REQUEST['page']) ? '&page=' . $_REQUEST['page'] : '' ; |
|
header('Location:index.php?do=rubs' . $page . '&cp=' . SESSION); |
|
} |
|
|
|
exit; |
|
} |
|
} |
|
|
|
|
|
/** |
|
* Копирование рубрики |
|
* |
|
*/ |
|
function rubricCopy() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$rubric_id = (int)$_REQUEST['Id']; |
|
|
|
$errors = array(); |
|
|
|
if (empty($_REQUEST['rubric_title'])) |
|
{ |
|
array_push($errors, $AVE_Template->get_config_vars('RUBRIK_NO_NAME')); |
|
} |
|
else |
|
{ |
|
$name_exist = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
rubric_title = '" . $_POST['rubric_title'] . "' |
|
LIMIT 1 |
|
")->NumRows(); |
|
|
|
if ($name_exist) |
|
array_push($errors, $AVE_Template->get_config_vars('RUBRIK_NAME_EXIST')); |
|
} |
|
|
|
if (! empty($_POST['rubric_alias'])) |
|
{ |
|
if (preg_match(TRANSLIT_URL ? '/[^\%HYa-z0-9\/-]+/' : '/[^\%HYa-zа-яёїєі0-9\/_-]+/', $_POST['rubric_alias'])) |
|
{ |
|
array_push($errors, $AVE_Template->get_config_vars('RUBRIK_PREFIX_BAD_CHAR')); |
|
} |
|
else |
|
{ |
|
$prefix_exist = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
rubric_alias = '" . $_POST['rubric_alias'] . "' |
|
LIMIT 1 |
|
")->NumRows(); |
|
|
|
if ($prefix_exist) |
|
array_push($errors, $AVE_Template->get_config_vars('RUBRIK_PREFIX_EXIST')); |
|
} |
|
} |
|
|
|
$row = $AVE_DB->Query(" |
|
SELECT * |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
")->FetchRow(); |
|
|
|
if (! $row) |
|
array_push($errors, $AVE_Template->get_config_vars('RUBRIK_NO_RUBRIK')); |
|
|
|
if (! empty($errors)) |
|
{ |
|
$AVE_Template->assign('errors', $errors); |
|
} |
|
else |
|
{ |
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_title = '" . $_POST['rubric_title'] . "', |
|
rubric_alias = '" . $_POST['rubric_alias'] . "', |
|
rubric_template = '" . addslashes($row->rubric_template) . "', |
|
rubric_template_id = '" . addslashes($row->rubric_template_id) . "', |
|
rubric_author_id = '" . (int)$_SESSION['user_id'] . "', |
|
rubric_created = '" . time() . "', |
|
rubric_teaser_template = '" . addslashes($row->rubric_teaser_template) . "', |
|
rubric_header_template = '" . addslashes($row->rubric_header_template) . "', |
|
rubric_footer_template = '" . addslashes($row->rubric_footer_template) . "', |
|
rubric_admin_teaser_template = '" . addslashes($row->rubric_admin_teaser_template) . "', |
|
rubric_changed = '" . time() . "', |
|
rubric_changed_fields = '" . time() . "' |
|
"); |
|
|
|
$iid = $AVE_DB->InsertId(); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
user_group_id, |
|
rubric_permission |
|
FROM |
|
" . PREFIX . "_rubric_permissions |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubric_permissions |
|
SET |
|
rubric_id = '" . $iid . "', |
|
user_group_id = '" . (int)$row->user_group_id . "', |
|
rubric_permission = '" . addslashes($row->rubric_permission) . "' |
|
"); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rubric_field_title, |
|
rubric_field_alias, |
|
rubric_field_type, |
|
rubric_field_position, |
|
rubric_field_default, |
|
rubric_field_template, |
|
rubric_field_template_request, |
|
rubric_field_description |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
ORDER BY rubric_field_position ASC |
|
"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_id = '" . $iid . "', |
|
rubric_field_title = '" . addslashes($row->rubric_field_title) . "', |
|
rubric_field_alias = '" . addslashes($row->rubric_field_alias) . "', |
|
rubric_field_type = '" . addslashes($row->rubric_field_type) . "', |
|
rubric_field_position = '" . (int)$row->rubric_field_position . "', |
|
rubric_field_default = '" . addslashes($row->rubric_field_default) . "', |
|
rubric_field_template = '" . addslashes($row->rubric_field_template) . "', |
|
rubric_field_template_request = '" . addslashes($row->rubric_field_template_request) . "', |
|
rubric_field_description = '" . addslashes($row->rubric_field_description) . "' |
|
"); |
|
} |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_COPY') . ' - ' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title, ENT_QUOTES)) . ' (id: '.$rubric_id.')'); |
|
|
|
echo '<script>window.opener.location.reload();window.close();</script>'; |
|
} |
|
} |
|
|
|
|
|
/** |
|
* Удаление рубрики |
|
* |
|
*/ |
|
function rubricDelete() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$rubric_id = (int)$_REQUEST['Id']; |
|
|
|
if ($rubric_id <= 1) |
|
{ |
|
header('Location:index.php?do=rubs&cp=' . SESSION); |
|
exit; |
|
} |
|
|
|
$rubric_not_empty = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_documents |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
LIMIT 1 |
|
")->GetCell(); |
|
|
|
if (!$rubric_not_empty) |
|
{ |
|
$AVE_DB->Query(" |
|
DELETE FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->Query(" |
|
DELETE FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->Query(" |
|
DELETE FROM |
|
" . PREFIX . "_rubric_permissions |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->Query(" |
|
DELETE FROM |
|
" . PREFIX . "_rubric_templates |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
// Удалить КЕШ |
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
// Удалить файлы шаблонов |
|
$this->clearTemplates($rubric_id); |
|
|
|
// Сохраняем системное сообщение в журнал |
|
reportLog($AVE_Template->get_config_vars('RUBRIK_LOG_DEL_RUBRIC') . ' - ' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title, ENT_QUOTES)) . ' (id: '.$rubric_id.')'); |
|
} |
|
|
|
header('Location:index.php?do=rubs&cp=' . SESSION); |
|
exit; |
|
} |
|
|
|
|
|
/** |
|
* Вывод списка полей рубрики |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricFieldShow($rubric_id = 0, $ajax) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
if (check_permission_acp('rubric_edit')) |
|
{ |
|
// Поля |
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
a.*, |
|
b.group_title, |
|
b.group_description, |
|
b.group_position |
|
FROM |
|
" . PREFIX . "_rubric_fields AS a |
|
LEFT JOIN |
|
" . PREFIX . "_rubric_fields_group AS b |
|
ON a.rubric_field_group = b.Id |
|
WHERE |
|
a.rubric_id = '" . $rubric_id . "' |
|
ORDER BY |
|
b.group_position ASC, a.rubric_field_position ASC |
|
"); |
|
|
|
$fields_list = array(); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$group_id = ($row->rubric_field_group) ? $row->rubric_field_group : 0; |
|
|
|
$fields_list[$group_id]['group_position'] = ($row->group_position) ? $row->group_position : 100; |
|
$fields_list[$group_id]['group_title'] = $row->group_title; |
|
$fields_list[$group_id]['group_description'] = $row->group_description; |
|
$fields_list[$group_id]['fields'][$row->Id]['Id'] = $row->Id; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_id'] = $row->rubric_id; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_group'] = $row->rubric_field_group; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_alias'] = $row->rubric_field_alias; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_title'] = $row->rubric_field_title; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_type'] = $row->rubric_field_type; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_numeric'] = $row->rubric_field_numeric; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_default'] = $row->rubric_field_default; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_search'] = $row->rubric_field_search; |
|
} |
|
|
|
$fields_list = msort($fields_list, 'group_position'); |
|
|
|
$AVE_Template->assign('groups_count', count($fields_list)); |
|
$AVE_Template->assign('fields_list', $fields_list); |
|
|
|
// Группы полей |
|
$fields_groups = array(); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT * |
|
FROM |
|
" . PREFIX . "_rubric_fields_group |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
ORDER BY |
|
group_position ASC |
|
"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
array_push($fields_groups, $row); |
|
|
|
$AVE_Template->assign('fields_groups', $fields_groups); |
|
|
|
// Права |
|
$groups = array(); |
|
|
|
$sql = $AVE_DB->Query("SELECT * FROM " . PREFIX . "_user_groups"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$row->doall = ($row->user_group == 1) ? ' disabled="disabled" checked="checked"' : ''; |
|
$row->doall_h = ($row->user_group == 1) ? 1 : ''; |
|
|
|
$rubric_permission = $AVE_DB->Query(" |
|
SELECT |
|
rubric_permission |
|
FROM |
|
" . PREFIX . "_rubric_permissions |
|
WHERE |
|
user_group_id = '" . $row->user_group . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
")->GetCell(); |
|
|
|
$row->permissions = @explode('|', $rubric_permission); |
|
|
|
array_push($groups,$row); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title, |
|
rubric_linked_rubric, |
|
rubric_description |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
id = '" . $rubric_id . "' |
|
LIMIT 1 |
|
"); |
|
|
|
$rubrik = $sql->FetchRow(); |
|
|
|
$rubrik->rubric_linked_rubric = ($rubrik->rubric_linked_rubric != '0') |
|
? unserialize($rubrik->rubric_linked_rubric) |
|
: array(); |
|
|
|
$AVE_Template->assign('rubric', $rubrik); |
|
$AVE_Template->assign('groups', $groups); |
|
$AVE_Template->assign('fields', get_field_type()); |
|
$AVE_Template->assign('rubs', $this->rubricShow()); |
|
|
|
if (isAjax()) |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/fields.tpl')); |
|
else |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/fields_list.tpl')); |
|
} |
|
else |
|
{ |
|
header('Location:index.php?do=rubs&cp=' . SESSION); |
|
exit; |
|
} |
|
} |
|
|
|
|
|
/** |
|
* Вывод списка полей рубрики |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricRulesShow($rubric_id = 0) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
if (check_permission_acp('rubric_edit')) |
|
{ |
|
// Права |
|
$groups = array(); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
* |
|
FROM |
|
" . PREFIX . "_user_groups |
|
"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$row->doall = ($row->user_group == 1) ? ' disabled="disabled" checked="checked"' : ''; |
|
$row->doall_h = ($row->user_group == 1) ? 1 : ''; |
|
|
|
$rubric_permission = $AVE_DB->Query(" |
|
SELECT |
|
rubric_permission |
|
FROM |
|
" . PREFIX . "_rubric_permissions |
|
WHERE |
|
user_group_id = '" . $row->user_group . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
")->GetCell(); |
|
|
|
$row->permissions = @explode('|', $rubric_permission); |
|
|
|
array_push($groups,$row); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title, |
|
rubric_linked_rubric, |
|
rubric_description |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
id = '" . $rubric_id . "' |
|
LIMIT 1 |
|
"); |
|
|
|
$rubric = $sql->FetchRow(); |
|
|
|
$AVE_Template->assign('rubric', $rubric); |
|
$AVE_Template->assign('groups', $groups); |
|
|
|
if (isAjax()) |
|
{ |
|
|
|
} |
|
else |
|
{ |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/rules.tpl')); |
|
} |
|
} |
|
else |
|
{ |
|
header('Location:index.php?do=rubs&cp=' . SESSION); |
|
exit; |
|
} |
|
} |
|
|
|
|
|
|
|
/** |
|
* Вывод списка рубрик |
|
* |
|
* @param int $rubric_id идентификатор текущей рубрики |
|
*/ |
|
function rubricShow($RubLink=null) |
|
{ |
|
global $AVE_DB; |
|
|
|
if ($RubLink !== null) |
|
{ |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_linked_rubric = '" . serialize($_REQUEST['rubric_linked']) . "' |
|
WHERE |
|
Id = '" . (int)$_REQUEST['Id'] . "' |
|
"); |
|
|
|
header('Location:index.php?do=rubs&action=edit&Id=' . (int)$_REQUEST['Id'] . '&cp=' . SESSION); |
|
exit; |
|
} |
|
else |
|
{ |
|
$rubs = array(); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title, |
|
Id |
|
FROM |
|
" . PREFIX . "_rubrics |
|
ORDER BY |
|
rubric_position ASC |
|
"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
array_push($rubs, $row); |
|
|
|
return $rubs; |
|
} |
|
} |
|
|
|
/** |
|
* Создание нового поля рубрики |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricFieldNew($rubric_id = 0, $ajax) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
if (! empty($_POST['title_new'])) |
|
{ |
|
$position = (int)$AVE_DB->Query(" |
|
SELECT |
|
MAX(rubric_field_position) |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
")->GetCell() + 1; |
|
|
|
if ($_POST['rub_type_new'] == 'dropdown') |
|
{ |
|
$rubric_field_default = trim($_POST['default_value']); |
|
$rubric_field_default = preg_split('/\s*,\s*/', $rubric_field_default); |
|
$rubric_field_default = implode(',', $rubric_field_default); |
|
} |
|
else |
|
{ |
|
$rubric_field_default = $_POST['default_value']; |
|
} |
|
|
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_id = '" . $rubric_id . "', |
|
rubric_field_group = '" . (($_POST['group_new'] != '') ? (int)$_POST['group_new'] : '0') . "', |
|
rubric_field_title = '" . $_POST['title_new'] . "', |
|
rubric_field_type = '" . $_POST['rub_type_new'] . "', |
|
rubric_field_position = '" . $position . "', |
|
rubric_field_default = '" . $rubric_field_default . "', |
|
rubric_field_numeric = '" . (($_POST['rubric_field_numeric'] == 1) ? $_POST['rubric_field_numeric'] : '0') . "', |
|
rubric_field_search = '" . (($_POST['rubric_field_search'] == 1) ? $_POST['rubric_field_search'] : '0') . "' |
|
"); |
|
|
|
$UpdateRubricField = $AVE_DB->InsertId(); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
Id |
|
FROM |
|
" . PREFIX . "_documents |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_document_fields |
|
SET |
|
rubric_field_id = '" . $UpdateRubricField . "', |
|
document_id = '" . $row->Id . "' |
|
"); |
|
} |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed_fields = '" . time() . "' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
// Сохраняем системное сообщение в журнал |
|
reportLog($AVE_Template->get_config_vars('RUBRIK_LOG_NEW_FIELD').' (' . stripslashes(htmlspecialchars($_POST['title_new'], ENT_QUOTES)) . ') '. stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title, ENT_QUOTES)). ' (id: '.$rubric_id.')'); |
|
} |
|
else |
|
{ |
|
if (! isAjax()) |
|
{ |
|
header('Location:index.php?do=rubs&action=edit&Id=' . $rubric_id . '&cp=' . SESSION); |
|
} |
|
else |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_EMPTY_MESSAGE'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_FILDS_SUCCESS'); |
|
$theme = 'error'; |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
|
|
exit; |
|
} |
|
|
|
if (! isAjax()) |
|
{ |
|
header('Location:index.php?do=rubs&action=edit&Id=' . $rubric_id . '&cp=' . SESSION); |
|
} |
|
else |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_FILD_SAVED'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_FILDS_SUCCESS'); |
|
$theme = 'accept'; |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
|
|
exit; |
|
} |
|
|
|
|
|
/** |
|
* Редактирование кода для рубрики |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricCodeEdit($rubric_id = 0) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
switch ($_REQUEST['sub']) { |
|
|
|
case '': |
|
$code = $AVE_DB->Query(" |
|
SELECT |
|
rubric_code_start, |
|
rubric_code_end, |
|
rubric_start_code |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
")->FetchRow(); |
|
|
|
$AVE_Template->assign('code', $code); |
|
$AVE_Template->assign('rubric_title', $this->rubricNameByIdGet($rubric_id)->rubric_title); |
|
$AVE_Template->assign('formaction', 'index.php?do=rubs&action=code&sub=save&Id=' . $rubric_id . '&cp=' . SESSION); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/code.tpl')); |
|
break; |
|
|
|
case 'save': |
|
$sql = $AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_start_code = '" . $_POST['rubric_start_code'] . "', |
|
rubric_code_start = '" . $_POST['rubric_code_start'] . "', |
|
rubric_code_end = '" . $_POST['rubric_code_end'] . "', |
|
rubric_changed = '" . time() . "' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
// Очищаем кэш рубрики |
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
if ($sql !== true) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_CODE_SAVED_ERR'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_CODE_ERROR'); |
|
$theme = 'error'; |
|
} |
|
else |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_CODE_SAVED'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_CODE_SUCCESS'); |
|
$theme = 'accept'; |
|
reportLog($AVE_Template->get_config_vars('RUBRIK_CODE_UPDATE') . " (" . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title, ENT_QUOTES)) . ") (id: $rubric_id)"); |
|
} |
|
|
|
if (isAjax()) |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
else |
|
header('Location:index.php?do=rubs&action=code&Id=' . $rubric_id . '&cp=' . SESSION); |
|
|
|
exit; |
|
} |
|
} |
|
|
|
/** |
|
* Редактирование кода для рубрики |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricCode($rubric_id = 0) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$sql = $AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_start_code = '" . $_POST['rubric_start_code'] . "', |
|
rubric_code_start = '" . $_POST['rubric_code_start'] . "', |
|
rubric_code_end = '" . $_POST['rubric_code_end'] . "', |
|
rubric_changed = '" . time() . "' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
if ($sql->_result === false) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_CODE_SAVED_ERR'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_CODE_ERROR'); |
|
$theme = 'error'; |
|
} |
|
else |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_CODE_SAVED'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_CODE_SUCCESS'); |
|
$theme = 'accept'; |
|
reportLog($AVE_Template->get_config_vars('RUBRIK_CODE_UPDATE') . " (" . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title, ENT_QUOTES)) . ") (id: $rubric_id)"); |
|
} |
|
|
|
if (isAjax()) |
|
{ |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
else |
|
{ |
|
header('Location:index.php?do=rubs&action=edit&Id=' . $rubric_id . '&cp=' . SESSION); |
|
} |
|
exit; |
|
} |
|
|
|
/** |
|
* Редактирование описания рубрики |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricDesc($rubric_id = 0) |
|
{ |
|
global $AVE_DB; |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_description = '" . $_POST['rubric_description'] . "' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
header('Location:index.php?do=rubs&action=edit&Id=' . $rubric_id . '&cp=' . SESSION); |
|
exit; |
|
} |
|
|
|
/** |
|
* Управление полями рубрики |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricFieldSave($rubric_id = 0) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
foreach ($_POST['title'] as $id => $title) |
|
{ |
|
if (! empty($title)) |
|
{ |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_field_title = '" . $title . "', |
|
rubric_field_numeric = '" . $_POST['rubric_field_numeric'][$id] . "', |
|
rubric_field_search = '" . $_POST['rubric_field_search'][$id] . "' |
|
WHERE |
|
Id = '" . $id . "' |
|
"); |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_FIELD_EDIT') . ' (' . stripslashes($title) . ') '.$AVE_Template->get_config_vars('RUBRIK_REPORT_RUB').' (' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title)) . ') (Id:' . $rubric_id . ')'); |
|
} |
|
} |
|
|
|
foreach ($_POST['del'] as $id => $Del) |
|
{ |
|
if (! empty($Del)) |
|
{ |
|
$AVE_DB->Query(" |
|
DELETE FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
Id = '" . $id . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->Query(" |
|
DELETE FROM |
|
" . PREFIX . "_document_fields |
|
WHERE |
|
rubric_field_id = '" . $id . "' |
|
"); |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_FIELD_DEL') . ' (' . stripslashes($_POST['title'][$id]) . ') '.$AVE_Template->get_config_vars('RUBRIK_REPORT_RUB').' (' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title)) . ') (Id:' . $rubric_id . ')'); |
|
} |
|
} |
|
|
|
// Очищаем кэш шаблона документов рубрики |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed = '" . time() . "', |
|
rubric_changed_fields = '" . time() . "' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
$message = $AVE_Template->get_config_vars('RUBRIK_FILDS_SAVED'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_FILDS_SUCCESS'); |
|
$theme = 'accept'; |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_FILDS_REPORT') . ' (' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title)) . ') (Id:' . $rubric_id . ')'); |
|
|
|
if (isAjax()) |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
else |
|
{ |
|
$AVE_Template->assign('message', $message); |
|
header('Location:index.php?do=rubs&action=edit&Id=' . $rubric_id . '&cp=' . SESSION); |
|
} |
|
|
|
exit; |
|
} |
|
|
|
/** |
|
* Сортировка полей рубрики |
|
* |
|
* @param array $sorted последовательность id полей |
|
*/ |
|
function rubricFieldsSort() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
foreach ($_REQUEST['sort'] as $position => $field_id) |
|
{ |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_field_position = '" . (int)$position . "' |
|
WHERE |
|
Id = '" . (int)$field_id . "' |
|
"); |
|
} |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_SORTE_FIELDS')); |
|
|
|
if (isAjax()) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_SORTED'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_FILDS_SUCCESS'); |
|
$theme = 'accept'; |
|
|
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
|
|
} |
|
|
|
/** |
|
* Сортировка рубрик |
|
* |
|
* @param array $sorted последовательность id полей |
|
*/ |
|
function rubricsSort() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
foreach ($_REQUEST['sort'] as $position => $rub_id) |
|
{ |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_position = '" . (int)$position . "' |
|
WHERE |
|
Id = '" . (int)$rub_id . "' |
|
"); |
|
} |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_SORTE')); |
|
|
|
if (isAjax()) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_SORTED'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_FILDS_SUCCESS'); |
|
$theme = 'accept'; |
|
|
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
} |
|
|
|
/** |
|
* Вывод шаблона рубрики |
|
* |
|
* @param int $show |
|
* @param int $extern |
|
*/ |
|
function rubricTemplateShow($show = '', $extern = '0') |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
if ($extern == 1) |
|
$fetchId = (isset($_REQUEST['rubric_id']) && is_numeric($_REQUEST['rubric_id'])) ? $_REQUEST['rubric_id'] : 0; |
|
else |
|
$fetchId = (isset($_REQUEST['Id']) && is_numeric($_REQUEST['Id'])) ? $_REQUEST['Id'] : 0; |
|
|
|
$rubric = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title, |
|
rubric_template, |
|
rubric_header_template, |
|
rubric_footer_template, |
|
rubric_teaser_template, |
|
rubric_admin_teaser_template, |
|
rubric_description |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
Id = '" . $fetchId . "' |
|
")->FetchRow(); |
|
|
|
// Поля |
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
a.*, |
|
b.group_title, |
|
b.group_description, |
|
b.group_position |
|
FROM |
|
" . PREFIX . "_rubric_fields AS a |
|
LEFT JOIN |
|
" . PREFIX . "_rubric_fields_group AS b |
|
ON a.rubric_field_group = b.Id |
|
WHERE |
|
a.rubric_id = '" . $fetchId . "' |
|
ORDER BY |
|
b.group_position ASC, a.rubric_field_position ASC |
|
"); |
|
|
|
$fields_list = array(); |
|
$drop_down_fields = array(); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$group_id = ($row->rubric_field_group) ? $row->rubric_field_group : 0; |
|
|
|
if ($row->rubric_field_type == 'drop_down' || $row->rubric_field_type == 'drop_down_key') |
|
array_push($drop_down_fields, $row->Id); |
|
|
|
$fields_list[$group_id]['group_position'] = ($row->group_position) ? $row->group_position : 100; |
|
$fields_list[$group_id]['group_title'] = $row->group_title; |
|
$fields_list[$group_id]['group_description'] = $row->group_description; |
|
$fields_list[$group_id]['fields'][$row->Id]['Id'] = $row->Id; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_id'] = $row->rubric_id; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_group'] = $row->rubric_field_group; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_alias'] = $row->rubric_field_alias; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_title'] = $row->rubric_field_title; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_type'] = $row->rubric_field_type; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_numeric'] = $row->rubric_field_numeric; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_default'] = $row->rubric_field_default; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_search'] = $row->rubric_field_search; |
|
} |
|
|
|
$fields_list = msort($fields_list, 'group_position'); |
|
|
|
$AVE_Template->assign('groups_count', count($fields_list)); |
|
$AVE_Template->assign('fields_list', $fields_list); |
|
|
|
$AVE_Template->assign('field_array', get_field_type()); |
|
|
|
if ($show == 1 ) |
|
$rubric->rubric_template = stripslashes($_POST['rubric_template']); |
|
|
|
if ($extern == 1) |
|
{ |
|
$AVE_Template->assign('ddid', implode(',', $drop_down_fields)); |
|
} |
|
else |
|
{ |
|
$AVE_Template->assign('rubric', $rubric); |
|
$AVE_Template->assign('formaction', 'index.php?do=rubs&action=template&sub=save&Id=' . $fetchId . '&cp=' . SESSION); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/form.tpl')); |
|
} |
|
} |
|
|
|
/** |
|
* Редактирование шаблона рубрики |
|
* |
|
* @param string $data |
|
*/ |
|
function rubricTemplateSave($Rtemplate, $Htemplate = '', $Ttemplate = '', $Atemplate = '', $Ftemplate = '') |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$rubric_id = (int)$_REQUEST['Id']; |
|
|
|
$sql = $AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_template = '" . ($Rtemplate) . "', |
|
rubric_header_template = '" . $Htemplate . "', |
|
rubric_footer_template = '" . $Ftemplate . "', |
|
rubric_teaser_template = '" . $Ttemplate . "', |
|
rubric_admin_teaser_template = '" . $Atemplate . "', |
|
rubric_changed = '" . time() . "' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
if ($sql === false) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_TPL_ERR'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_ERROR'); |
|
$theme = 'error'; |
|
} |
|
else |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_TPL'); |
|
$header = $AVE_Template->get_config_vars('RUBRIC_SUCCESS'); |
|
$theme = 'accept'; |
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_TEMPL_RUB') . ' (' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title)) . ') (Id:' . $rubric_id . ')'); |
|
} |
|
|
|
if (isAjax()) |
|
{ |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
else |
|
{ |
|
$AVE_Template->assign('message', $message); |
|
header('Location:index.php?do=rubs&cp=' . SESSION); |
|
} |
|
|
|
exit; |
|
} |
|
|
|
/** |
|
* Управление правами доступа к документам рубрик |
|
* |
|
* @param int $rubric_id идентификатор рубрики |
|
*/ |
|
function rubricPermissionSave($rubric_id = 0) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
if (check_permission_acp('rubric_perms') && is_numeric($rubric_id) && $rubric_id > 0) |
|
{ |
|
foreach ($_POST['user_group'] as $key => $user_group_id) |
|
{ |
|
$exist = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM |
|
" . PREFIX . "_rubric_permissions |
|
WHERE |
|
user_group_id = '" . $user_group_id . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
LIMIT 1 |
|
")->NumRows(); |
|
|
|
$rubric_permission = @implode('|', $_POST['perm'][$key]); |
|
|
|
if ($exist) |
|
{ |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_permissions |
|
SET |
|
rubric_permission = '" . $rubric_permission . "' |
|
WHERE |
|
user_group_id = '" . $user_group_id . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
} |
|
else |
|
{ |
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubric_permissions |
|
SET |
|
rubric_id = '" . $rubric_id . "', |
|
user_group_id = '" . $user_group_id . "', |
|
rubric_permission = '" . $rubric_permission . "' |
|
"); |
|
} |
|
} |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed = '" . time() . "' |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_PERMS'); |
|
$header = $AVE_Template->get_config_vars('RUBRIC_SUCCESS'); |
|
$theme = 'accept'; |
|
|
|
reportLog($AVE_Template->get_config_vars('RUBRIK_REPORT_PERMISION') . ' (' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title)) . ') (Id:' . $rubric_id . ')'); |
|
|
|
if (isAjax()) |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
else |
|
header('Location:index.php?do=rubs&action=edit&Id=' . $rubric_id . '&cp=' . SESSION); |
|
|
|
exit; |
|
} |
|
} |
|
|
|
/** |
|
* Получить наименование и URL-префикс Рубрики по идентификатору |
|
* |
|
* @param int $rubric_id идентификатор Рубрики |
|
* @return object наименование Рубрики |
|
*/ |
|
function rubricNameByIdGet($rubric_id = 0) |
|
{ |
|
global $AVE_DB; |
|
|
|
static $rubrics = array(); |
|
|
|
if (! isset($rubrics[$rubric_id])) |
|
{ |
|
$rubrics[$rubric_id] = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title, |
|
rubric_alias, |
|
rubric_description |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
LIMIT 1 |
|
")->FetchRow(); |
|
} |
|
|
|
return $rubrics[$rubric_id]; |
|
} |
|
|
|
/** |
|
* Формирование прав доступа Групп пользователей на все Рубрики |
|
* |
|
*/ |
|
function rubricPermissionFetch() |
|
{ |
|
global $AVE_DB, $AVE_Document, $AVE_Template; |
|
|
|
$items = array(); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
Id, |
|
rubric_title, |
|
rubric_docs_active |
|
FROM |
|
" . PREFIX . "_rubrics |
|
ORDER |
|
BY rubric_position |
|
"); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$AVE_Document->documentPermissionFetch($row->Id); |
|
|
|
if (defined('UGROUP') && UGROUP == 1) $row->Show = 1; |
|
elseif (isset($_SESSION[$row->Id . '_editown']) && $_SESSION[$row->Id . '_editown'] == 1) $row->Show = 1; |
|
elseif (isset($_SESSION[$row->Id . '_editall']) && $_SESSION[$row->Id . '_editall'] == 1) $row->Show = 1; |
|
elseif (isset($_SESSION[$row->Id . '_new']) && $_SESSION[$row->Id . '_new'] == 1) $row->Show = 1; |
|
elseif (isset($_SESSION[$row->Id . '_newnow']) && $_SESSION[$row->Id . '_newnow'] == 1) $row->Show = 1; |
|
elseif (isset($_SESSION[$row->Id . '_alles']) && $_SESSION[$row->Id . '_alles'] == 1) $row->Show = 1; |
|
|
|
array_push($items, $row); |
|
} |
|
|
|
$AVE_Template->assign('rubrics', $items); |
|
} |
|
|
|
/** |
|
* Получить |
|
*/ |
|
function rubricAliasAdd() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
a.rubric_title, |
|
b.rubric_field_title, |
|
b.rubric_field_alias |
|
FROM |
|
" . PREFIX . "_rubrics AS a |
|
JOIN |
|
" . PREFIX . "_rubric_fields AS b |
|
WHERE |
|
a.Id = '" . $_REQUEST['rubric_id'] . "' |
|
AND |
|
b.Id = '" . $_REQUEST['field_id'] . "' |
|
")->FetchAssocArray(); |
|
|
|
$AVE_Template->assign($sql); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/alias.tpl')); |
|
} |
|
|
|
|
|
function rubricAliasCheck($rubric_id, $field_id, $value) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$errors = array(); |
|
|
|
if (! intval($rubric_id)>0) |
|
$errors[] = $AVE_Template->get_config_vars('RUBRIK_ALIAS_RUBID'); |
|
|
|
if (! intval($field_id)>0) |
|
$errors[] = $AVE_Template->get_config_vars('RUBRIK_ALIAS_FIELDID'); |
|
|
|
if (! preg_match('/^[A-Za-z][[:word:]]{0,19}$/', $value)) |
|
$errors[] = $AVE_Template->get_config_vars('RUBRIK_ALIAS_MATCH'); |
|
|
|
//Проверяем есть такой алиас уже |
|
$res = $AVE_DB->Query(" |
|
SELECT |
|
COUNT(*) |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
Id <> " . intval($field_id) . " |
|
AND rubric_id = " . intval($rubric_id) . " |
|
AND rubric_field_alias = '" . addslashes($value) . "' |
|
")->GetCell(); |
|
|
|
if ($res > 0) |
|
$errors[] = $AVE_Template->get_config_vars('RUBRIK_ALIAS_MATCH'); |
|
|
|
if (empty($errors)) |
|
{ |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_field_alias = '" . addslashes($value) . "' |
|
WHERE |
|
Id = '" . intval($field_id) . "' |
|
AND |
|
rubric_id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_Template->assign('success', true); |
|
} |
|
else |
|
{ |
|
$AVE_Template->assign('errors', $errors); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
a.rubric_title, |
|
b.rubric_field_title, |
|
b.rubric_field_alias |
|
FROM |
|
" . PREFIX . "_rubrics AS a |
|
JOIN |
|
" . PREFIX . "_rubric_fields AS b |
|
WHERE |
|
a.Id = '" . $_REQUEST['rubric_id'] . "' |
|
AND |
|
b.Id = '" . $_REQUEST['field_id'] . "' |
|
")->FetchAssocArray(); |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed_fields = '" . time() . "' |
|
WHERE |
|
Id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_Template->assign($sql); |
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/alias.tpl')); |
|
} |
|
|
|
function rubricFieldTemplate() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$field = $AVE_DB->Query(" |
|
SELECT |
|
a.rubric_title, |
|
b.rubric_field_default, |
|
b.rubric_field_title, |
|
b.rubric_field_template, |
|
b.rubric_field_template_request, |
|
b.rubric_field_description |
|
FROM |
|
" . PREFIX . "_rubrics AS a |
|
JOIN |
|
" . PREFIX . "_rubric_fields AS b |
|
WHERE |
|
a.Id = '" . $_REQUEST['rubric_id'] . "' |
|
AND |
|
b.Id = '" . $_REQUEST['field_id'] . "' |
|
")->FetchAssocArray(); |
|
|
|
$AVE_Template->assign($field); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/field_template.tpl')); |
|
} |
|
|
|
|
|
function rubricFieldTemplateSave($id, $rubric_id) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$sql = $AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_field_default = '" . $_POST['rubric_field_default'] . "', |
|
rubric_field_template = '" . $_POST['rubric_field_template'] . "', |
|
rubric_field_template_request = '" . $_POST['rubric_field_template_request'] . "', |
|
rubric_field_description = '" . $_POST['rubric_field_description'] . "' |
|
WHERE |
|
Id = '" . $id . "' |
|
"); |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed_fields = '" . time() . "' |
|
WHERE |
|
Id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
if ($sql === false) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_FLDTPL_ERR'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_ERROR'); |
|
$theme = 'error'; |
|
|
|
if (isAjax() && ! $_REQUEST['save']) |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
else |
|
$this->rubricFieldTemplate(); |
|
|
|
exit; |
|
} |
|
else |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_FLDTPL'); |
|
$header = $AVE_Template->get_config_vars('RUBRIC_SUCCESS'); |
|
$theme = 'accept'; |
|
|
|
if (isAjax()) |
|
{ |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
exit; |
|
} |
|
} |
|
} |
|
|
|
|
|
function rubricFieldChange($field_id, $rubric_id) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
* |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
AND |
|
Id = " . $field_id . " |
|
")->FetchAssocArray(); |
|
|
|
$AVE_Template->assign('rf', $sql); |
|
$AVE_Template->assign('fields', get_field_type()); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/change.tpl')); |
|
} |
|
|
|
|
|
function rubricFieldChangeSave($field_id, $rubric_id) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_field_type = '" . trim($_POST['rubric_field_type']) . "' |
|
WHERE |
|
Id = '" . $field_id . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
* |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
AND |
|
Id = " . $field_id . " |
|
")->FetchAssocArray(); |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed_fields = '" . time() . "' |
|
WHERE |
|
Id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_Template->assign('rf', $sql); |
|
$AVE_Template->assign('fields', get_field_type()); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/change.tpl')); |
|
} |
|
|
|
|
|
function rubricFieldsGroups($rubric_id) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
* |
|
FROM |
|
" . PREFIX . "_rubric_fields_group |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
ORDER BY |
|
group_position |
|
"); |
|
|
|
$groups = array(); |
|
|
|
while ($row = $sql->FetchRow()) |
|
array_push($groups, $row); |
|
|
|
$AVE_Template->assign('rubric', $this->rubricNameByIdGet($rubric_id)); |
|
$AVE_Template->assign('groups', $groups); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/fields_groups.tpl')); |
|
} |
|
|
|
/** |
|
* Сортировка групп полей рубрики |
|
* |
|
* @param array $sorted последовательность id полей |
|
*/ |
|
function rubricFieldsGroupsSort() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
foreach ($_REQUEST['sort'] as $position => $group_id) |
|
{ |
|
$position++; |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields_group |
|
SET |
|
group_position = '" . (int)$position . "' |
|
WHERE |
|
Id = '" . (int)$group_id . "' |
|
"); |
|
} |
|
|
|
if (isAjax()) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIK_SORTED'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_FILDS_SUCCESS'); |
|
$theme = 'accept'; |
|
|
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
exit; |
|
} |
|
} |
|
|
|
|
|
function rubricNewGroupFields($rubric_id) |
|
{ |
|
global $AVE_DB; |
|
|
|
$position = $AVE_DB->Query(" |
|
SELECT |
|
MAX(group_position) |
|
FROM |
|
" . PREFIX . "_rubric_fields_group |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
")->GetCell(); |
|
|
|
$position++; |
|
|
|
$AVE_DB->Query(" |
|
INSERT |
|
" . PREFIX . "_rubric_fields_group |
|
SET |
|
rubric_id = '" . $rubric_id . "', |
|
group_position = '" . $position . "', |
|
group_title= '" . $_REQUEST['group_title'] . "' |
|
"); |
|
|
|
header('Location:index.php?do=rubs&action=fieldsgroups&Id=' . $rubric_id . '&cp=' . SESSION); |
|
exit; |
|
} |
|
|
|
|
|
function rubricEditGroupFields($rubric_id) |
|
{ |
|
global $AVE_DB; |
|
|
|
foreach($_REQUEST['group_title'] as $k => $v) |
|
{ |
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields_group |
|
SET |
|
group_title= '" . $v . "' |
|
WHERE |
|
Id = '" . $k . "' |
|
"); |
|
} |
|
|
|
header('Location:index.php?do=rubs&action=fieldsgroups&Id=' . $rubric_id . '&cp=' . SESSION); |
|
exit; |
|
} |
|
|
|
|
|
function rubricDelGroupFields($Id, $rubric_id) |
|
{ |
|
global $AVE_DB; |
|
|
|
$AVE_DB->Query(" |
|
DELETE FROM |
|
" . PREFIX . "_rubric_fields_group |
|
WHERE |
|
Id = '" . $Id . "' |
|
"); |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_field_group = '0' |
|
WHERE |
|
rubric_field_group = '" . $Id . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
header('Location:index.php?do=rubs&action=fieldsgroups&Id=' . $rubric_id . '&cp=' . SESSION); |
|
exit; |
|
} |
|
|
|
|
|
function rubricFieldGroupChange($field_id, $rubric_id) |
|
{ |
|
|
|
global $AVE_DB, $AVE_Template; |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
* |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
AND |
|
Id = " . $field_id . " |
|
")->FetchAssocArray(); |
|
|
|
$AVE_Template->assign('rf', $sql); |
|
$AVE_Template->assign('groups', $this->get_rubric_fields_group($rubric_id)); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/groups.tpl')); |
|
} |
|
|
|
|
|
function rubricFieldGroupChangeSave($field_id, $rubric_id) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_fields |
|
SET |
|
rubric_field_group = '" . trim($_POST['rubric_field_group']) . "' |
|
WHERE |
|
Id = '" . $field_id . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
* |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
AND |
|
Id = " . $field_id . " |
|
")->FetchAssocArray(); |
|
|
|
$AVE_Template->assign('rf', $sql); |
|
$AVE_Template->assign('groups', $this->get_rubric_fields_group($rubric_id)); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/groups.tpl')); |
|
} |
|
|
|
|
|
// Список дополнительных шаблон для данной рубрики |
|
function tmplsList() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$templates = array(); |
|
|
|
$num = $AVE_DB->Query(" |
|
SELECT |
|
COUNT(*) |
|
FROM |
|
" . PREFIX . "_rubric_templates |
|
WHERE |
|
rubric_id = '" . $_REQUEST['Id'] . "' |
|
")->GetCell(); |
|
|
|
$page_limit = $this->_limit; |
|
|
|
$pages = ceil($num / $page_limit); |
|
|
|
$set_start = get_current_page() * $page_limit - $page_limit; |
|
|
|
if ($num > $page_limit) |
|
{ |
|
$page_nav = " <a class=\"pnav\" href=\"index.php?do=rubs&action=tmpls&page={s}&cp=" . SESSION . "\">{t}</a> "; |
|
$page_nav = get_pagination($pages, 'page', $page_nav); |
|
$AVE_Template->assign('page_nav', $page_nav); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rub.*, |
|
rubrics.rubric_title, |
|
(SELECT 1 FROM " . PREFIX . "_documents WHERE rubric_id = rub.rubric_id AND rubric_tmpl_id = rub.id LIMIT 1) AS doc_count |
|
FROM |
|
" . PREFIX . "_rubric_templates AS rub |
|
LEFT JOIN |
|
" . PREFIX . "_rubrics AS rubrics |
|
ON rubrics.Id = rub.rubric_id |
|
WHERE |
|
rub.rubric_id = '" . (int)$_REQUEST['Id'] . "' |
|
GROUP |
|
BY rub.id |
|
ORDER |
|
BY rub.id |
|
LIMIT |
|
" . $set_start . "," . $page_limit |
|
); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$row->author_id = get_username_by_id($row->author_id); |
|
array_push($templates, $row); |
|
} |
|
|
|
$rubric = $this->rubricNameByIdGet((int)$_REQUEST['Id']); |
|
|
|
$AVE_Template->assign('rubric', $rubric); |
|
$AVE_Template->assign('templates', $templates); |
|
} |
|
|
|
/** |
|
* Вывод шаблона рубрики |
|
* |
|
* @param int $show |
|
* @param int $extern |
|
*/ |
|
function tmplsEdit() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$tmpls_id = (isset($_REQUEST['id']) && is_numeric($_REQUEST['id'])) ? $_REQUEST['id'] : 0; |
|
$rubric_id = (int)$_REQUEST['rubric_id']; |
|
|
|
if ($tmpls_id) |
|
{ |
|
$template = $AVE_DB->Query(" |
|
SELECT |
|
title, |
|
template |
|
FROM |
|
" . PREFIX . "_rubric_templates |
|
WHERE |
|
id = '" . $tmpls_id . "' |
|
") |
|
->FetchRow(); |
|
} |
|
|
|
if ($_REQUEST['action'] == 'tmpls_from') |
|
{ |
|
$template = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title as title, |
|
rubric_template as template |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
Id = '" . $rubric_id . "' |
|
") |
|
->FetchRow(); |
|
} |
|
|
|
if ($_REQUEST['action'] == 'tmpls_copy') |
|
{ |
|
$template = $AVE_DB->Query(" |
|
SELECT |
|
title, |
|
template |
|
FROM |
|
" . PREFIX . "_rubric_templates |
|
WHERE |
|
id = '" . $_REQUEST['tmpls_id'] . "' |
|
") |
|
->FetchRow(); |
|
} |
|
|
|
// Поля |
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
a.*, |
|
b.group_title, |
|
b.group_description, |
|
b.group_position |
|
FROM |
|
" . PREFIX . "_rubric_fields AS a |
|
LEFT JOIN |
|
" . PREFIX . "_rubric_fields_group AS b |
|
ON a.rubric_field_group = b.Id |
|
WHERE |
|
a.rubric_id = '" . $rubric_id . "' |
|
ORDER BY |
|
b.group_position ASC, a.rubric_field_position ASC |
|
"); |
|
|
|
$fields_list = array(); |
|
$drop_down_fields = array(); |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$group_id = ($row->rubric_field_group) ? $row->rubric_field_group : 0; |
|
|
|
if ($row->rubric_field_type == 'drop_down' || $row->rubric_field_type == 'drop_down_key') |
|
array_push($drop_down_fields, $row->Id); |
|
|
|
$fields_list[$group_id]['group_position'] = ($row->group_position) ? $row->group_position : 100; |
|
$fields_list[$group_id]['group_title'] = $row->group_title; |
|
$fields_list[$group_id]['group_description'] = $row->group_description; |
|
$fields_list[$group_id]['fields'][$row->Id]['Id'] = $row->Id; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_id'] = $row->rubric_id; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_group'] = $row->rubric_field_group; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_alias'] = $row->rubric_field_alias; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_title'] = $row->rubric_field_title; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_type'] = $row->rubric_field_type; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_numeric'] = $row->rubric_field_numeric; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_default'] = $row->rubric_field_default; |
|
$fields_list[$group_id]['fields'][$row->Id]['rubric_field_search'] = $row->rubric_field_search; |
|
} |
|
|
|
$fields_list = msort($fields_list, 'group_position'); |
|
|
|
$AVE_Template->assign('groups_count', count($fields_list)); |
|
$AVE_Template->assign('fields_list', $fields_list); |
|
|
|
$AVE_Template->assign('field_array', get_field_type()); |
|
|
|
$rubric = $this->rubricNameByIdGet($rubric_id); |
|
|
|
$AVE_Template->assign('rubric', $rubric); |
|
|
|
$AVE_Template->assign('template', $template); |
|
|
|
$AVE_Template->assign('formaction', 'index.php?do=rubs&action=tmpls_edit&sub=save&id=' . $tmpls_id . '&rubric_id=' . $_REQUEST['rubric_id'] . '&cp=' . SESSION); |
|
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/tmpls_form.tpl')); |
|
} |
|
|
|
|
|
/** |
|
* Редактирование шаблона рубрики |
|
* |
|
* @param string $data |
|
*/ |
|
function tmplsSave($template = '', $title = '') |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$tmpls_id = (int)$_REQUEST['id']; |
|
$rubric_id = (int)$_REQUEST['rubric_id']; |
|
|
|
if ($tmpls_id) |
|
{ |
|
$sql = $AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubric_templates |
|
SET |
|
title = '" . $title . "', |
|
template = '" . $template . "' |
|
WHERE |
|
id = '" . $tmpls_id . "' |
|
"); |
|
} |
|
else |
|
{ |
|
$sql = $AVE_DB->Query(" |
|
INSERT INTO |
|
" . PREFIX . "_rubric_templates |
|
SET |
|
title = '" . $title . "', |
|
template = '" . $template . "', |
|
rubric_id = '" . $rubric_id . "', |
|
author_id = '" . UID . "', |
|
created = '" . time() . "' |
|
"); |
|
|
|
$tmpls_id = $AVE_DB->InsertId(); |
|
} |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed = '" . time() . "' |
|
WHERE |
|
Id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
if ($sql === false) |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_TPL_ERR'); |
|
$header = $AVE_Template->get_config_vars('RUBRIK_ERROR'); |
|
$theme = 'error'; |
|
} |
|
else |
|
{ |
|
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_TPL'); |
|
$header = $AVE_Template->get_config_vars('RUBRIC_SUCCESS'); |
|
$theme = 'accept'; |
|
reportLog($AVE_Template->get_config_vars('RUBRIC_TEMPL_REPORT') . ' ' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title)) . ' (Id шаблона:' . $tmpls_id . ')'); |
|
} |
|
|
|
if (isAjax()) |
|
{ |
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme)); |
|
} |
|
else |
|
{ |
|
$AVE_Template->assign('message', $message); |
|
header('Location:index.php?do=rubs&action=tmpls&Id='.$rubric_id.'&cp=' . SESSION); |
|
} |
|
|
|
exit; |
|
} |
|
|
|
|
|
function tmplsDelete() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$rubric_id = (int)$_REQUEST['rubric_id']; |
|
$tmpls_id = (int)$_REQUEST['tmpls_id']; |
|
|
|
$rubric_not_empty = $AVE_DB->Query(" |
|
SELECT 1 |
|
FROM " . PREFIX . "_documents |
|
WHERE |
|
rubric_id = '" . $rubric_id . "' |
|
AND |
|
rubric_tmpl_id = '" . $tmpls_id . "' |
|
LIMIT 1 |
|
")->GetCell(); |
|
|
|
if (! $rubric_not_empty) |
|
{ |
|
$AVE_DB->Query(" |
|
DELETE |
|
FROM |
|
" . PREFIX . "_rubric_templates |
|
WHERE |
|
id = '" . $tmpls_id . "' |
|
AND |
|
rubric_id = '" . $rubric_id . "' |
|
"); |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed = '" . time() . "' |
|
WHERE |
|
Id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
// Сохраняем системное сообщение в журнал |
|
reportLog($AVE_Template->get_config_vars('RUBRIC_TMPLS_LOG_DEL') . ' - ' . stripslashes(htmlspecialchars($this->rubricNameByIdGet($rubric_id)->rubric_title, ENT_QUOTES)) . ' (Id шаблона: '.$rubric_id.')'); |
|
} |
|
|
|
header('Location:index.php?do=rubs&action=tmpls&Id='.$rubric_id.'&cp=' . SESSION); |
|
exit; |
|
} |
|
|
|
|
|
|
|
function _get_fields_type($type = null) |
|
{ |
|
static $fields; |
|
|
|
if (is_array($fields)) |
|
return $fields; |
|
|
|
$arr = get_defined_functions(); |
|
|
|
$fields = array(); |
|
$field = array(); |
|
|
|
foreach ($arr['user'] as $v) |
|
{ |
|
if (trim(substr($v, 0, strlen('get_field_'))) == 'get_field_') |
|
{ |
|
$d = ''; |
|
|
|
$name = @$v('', 'name', '', '', 0, $d); |
|
|
|
$id = substr($v, strlen('get_field_')); |
|
|
|
if ($name != false && is_string($name)) |
|
$fields[] = array('id' => $id,'name' => (isset($fields_vars[$name]) |
|
? $fields_vars[$name] |
|
: $name)); |
|
|
|
if (! empty($type) && $id == $type) |
|
$field = array('id' => $id,'name' => (isset($fields_vars[$name]) |
|
? $fields_vars[$name] |
|
: $name)); |
|
} |
|
} |
|
|
|
$fields = msort($fields, array('name')); |
|
|
|
return (! empty($type)) ? $field : $fields; |
|
} |
|
|
|
|
|
function ShowFields() |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$rubric_id = (int)$_REQUEST['Id']; |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rubric_field_type |
|
FROM |
|
" . PREFIX . "_rubric_fields |
|
WHERE |
|
rubric_id = '".$rubric_id."' |
|
GROUP BY |
|
rubric_field_type |
|
"); |
|
|
|
$enable = array(); |
|
|
|
while ($row = $sql->FetchArray()) |
|
$enable[] = $row['rubric_field_type']; |
|
|
|
$fields = $this->_get_fields_type(); |
|
|
|
foreach ($fields as $field) |
|
{ |
|
$exists[$field['id']]['adm'] = file_exists(BASE_DIR . '/fields/' . $field['id'] . '/tpl/field.tpl'); |
|
$exists[$field['id']]['doc'] = file_exists(BASE_DIR . '/fields/' . $field['id'] . '/tpl/field-doc.tpl'); |
|
$exists[$field['id']]['req'] = file_exists(BASE_DIR . '/fields/' . $field['id'] . '/tpl/field-req.tpl'); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title, |
|
rubric_linked_rubric, |
|
rubric_description |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
id = '" . $rubric_id . "' |
|
LIMIT 1 |
|
"); |
|
|
|
$rubric = $sql->FetchRow(); |
|
|
|
$AVE_Template->assign('rubric', $rubric); |
|
$AVE_Template->assign("enable", $enable); |
|
$AVE_Template->assign("exists", $exists); |
|
$AVE_Template->assign("fields", $fields); |
|
$AVE_Template->assign("content", $AVE_Template->fetch('rubs/_fields_list.tpl')); |
|
} |
|
|
|
|
|
function ShowFieldsByType($fld) |
|
{ |
|
global $AVE_DB, $AVE_Template; |
|
|
|
$rubric_id = (int)$_REQUEST['rubric_id']; |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
a.Id, |
|
a.rubric_id, |
|
a.rubric_field_type, |
|
a.rubric_field_title, |
|
b.rubric_title |
|
FROM |
|
" . PREFIX . "_rubric_fields AS a |
|
LEFT JOIN |
|
" . PREFIX . "_rubrics AS b |
|
ON a.rubric_id = b.Id |
|
WHERE |
|
a.rubric_field_type = '" . $fld ."' |
|
AND |
|
a.rubric_id = '".$rubric_id."' |
|
ORDER BY |
|
a.rubric_id |
|
"); |
|
|
|
$rubrics = []; |
|
|
|
while ($row = $sql->FetchRow()) |
|
{ |
|
$rubrics[$row->rubric_id]['rubric_id'] = $row->rubric_id; |
|
$rubrics[$row->rubric_id]['rubric_title'] = $row->rubric_title; |
|
$rubrics[$row->rubric_id]['rubric_field_type'] = $row->rubric_field_type; |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['id'] = $row->Id; |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['title'] = $row->rubric_field_title; |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['adm_tpl'] = file_exists(BASE_DIR . '/fields/' . $fld . '/tpl/field-' . $row->Id . '.tpl'); |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['doc_tpl'] = file_exists(BASE_DIR . '/fields/' . $fld . '/tpl/field-doc-' . $row->Id . '.tpl'); |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['req_tpl'] = file_exists(BASE_DIR . '/fields/' . $fld . '/tpl/field-req-' . $row->Id . '.tpl'); |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['adm_main'] = file_exists(BASE_DIR . '/fields/' . $fld . '/tpl/field.tpl'); |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['doc_main'] = file_exists(BASE_DIR . '/fields/' . $fld . '/tpl/field-doc.tpl'); |
|
$rubrics[$row->rubric_id]['fields'][$row->Id]['req_main'] = file_exists(BASE_DIR . '/fields/' . $fld . '/tpl/field-req.tpl'); |
|
} |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
rubric_title, |
|
rubric_linked_rubric, |
|
rubric_description |
|
FROM |
|
" . PREFIX . "_rubrics |
|
WHERE |
|
id = '" . $rubric_id . "' |
|
LIMIT 1 |
|
"); |
|
|
|
$rubric = $sql->FetchRow(); |
|
|
|
$AVE_Template->assign('rubric', $rubric); |
|
$AVE_Template->assign('main', $this->_get_fields_type($fld)); |
|
$AVE_Template->assign("rubrics", $rubrics); |
|
$AVE_Template->assign("content", $AVE_Template->fetch('rubs/_field_list.tpl')); |
|
} |
|
|
|
|
|
function EditFieldTpl($id = '', $fld, $type) |
|
{ |
|
global $AVE_DB, $AVE_Template, $_fm_dir; |
|
|
|
switch ($type) |
|
{ |
|
case 'adm': |
|
$file = BASE_DIR . '/fields/' . $fld . '/tpl/field-' . $id . '.tpl'; |
|
$source = BASE_DIR . '/fields/' . $fld . '/tpl/field.tpl'; |
|
break; |
|
|
|
case 'doc': |
|
$file = BASE_DIR . '/fields/' . $fld . '/tpl/field-doc-' . $id . '.tpl'; |
|
$source = BASE_DIR . '/fields/' . $fld . '/tpl/field-doc.tpl'; |
|
break; |
|
|
|
case 'req': |
|
$file = BASE_DIR . '/fields/' . $fld . '/tpl/field-req-' . $id . '.tpl'; |
|
$source = BASE_DIR . '/fields/' . $fld . '/tpl/field-req.tpl'; |
|
break; |
|
} |
|
|
|
if (empty($id)) |
|
$file = $source; |
|
|
|
if (file_exists($file)) |
|
$code_text = file_get_contents($file); |
|
else |
|
$code_text = file_get_contents($source); |
|
|
|
$sql = $AVE_DB->Query(" |
|
SELECT |
|
a.rubric_field_title, |
|
b.rubric_title |
|
FROM |
|
" . PREFIX . "_rubric_fields AS a |
|
LEFT JOIN |
|
" . PREFIX . "_rubrics AS b |
|
ON a.rubric_id = b.Id |
|
WHERE |
|
a.rubric_field_type = '" . $fld ."' |
|
AND |
|
a.Id = '" . $id ."' |
|
")->FetchAssocArray(); |
|
|
|
$params = |
|
array( |
|
'id' => $id, |
|
'fld' => $fld, |
|
'type' => $type, |
|
'func' => (file_exists($file) ? 'edit' : 'new'), |
|
'field' => $sql, |
|
); |
|
|
|
$AVE_Template->assign('main', $this->_get_fields_type($fld)); |
|
$AVE_Template->assign('params', $params); |
|
$AVE_Template->assign('code_text', $code_text); |
|
$AVE_Template->assign("content", $AVE_Template->fetch('rubs/_field_code.tpl')); |
|
} |
|
|
|
|
|
/** |
|
* Сохранение шаблона |
|
* |
|
*/ |
|
function SaveFieldTpl($id = '', $fld, $type, $func) |
|
{ |
|
global $AVE_DB; |
|
|
|
switch ($type) |
|
{ |
|
case 'adm': |
|
$file = (! empty($id)) |
|
? BASE_DIR . '/fields/' . $fld . '/tpl/field-' . $id . '.tpl' |
|
: BASE_DIR . '/fields/' . $fld . '/tpl/field.tpl'; |
|
break; |
|
|
|
case 'doc': |
|
$file = (! empty($id)) |
|
? BASE_DIR . '/fields/' . $fld . '/tpl/field-doc-' . $id . '.tpl' |
|
: BASE_DIR . '/fields/' . $fld . '/tpl/field-doc.tpl'; |
|
break; |
|
|
|
case 'req': |
|
$file = (! empty($id)) |
|
? BASE_DIR . '/fields/' . $fld . '/tpl/field-req-' . $id . '.tpl' |
|
: BASE_DIR . '/fields/' . $fld . '/tpl/field-req.tpl'; |
|
break; |
|
} |
|
|
|
$data = stripcslashes($_REQUEST['code_text']); |
|
|
|
@file_put_contents($file, $data); |
|
chmod($file, 0644); |
|
|
|
$rubric_id = (int)$_REQUEST['rubric_id']; |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed_fields = '" . time() . "' |
|
WHERE |
|
Id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
$message = 'Шаблон успешнно сохранен'; |
|
$header = 'Выполнено'; |
|
$theme = 'accept'; |
|
|
|
echo json_encode( |
|
array( |
|
'message' => $message, |
|
'header' => $header, |
|
'theme' => $theme) |
|
); |
|
|
|
exit; |
|
} |
|
|
|
/** |
|
* Удаление шаблона поля |
|
* |
|
*/ |
|
function DeleteFieldTpl($id, $fld, $type, $func) |
|
{ |
|
global $AVE_DB; |
|
|
|
switch ($type) |
|
{ |
|
case 'adm': |
|
$file = BASE_DIR . '/fields/' . $fld . '/tpl/field-' . $id . '.tpl'; |
|
break; |
|
|
|
case 'doc': |
|
$file = BASE_DIR . '/fields/' . $fld . '/tpl/field-doc-' . $id . '.tpl'; |
|
break; |
|
|
|
case 'req': |
|
$file = BASE_DIR . '/fields/' . $fld . '/tpl/field-req-' . $id . '.tpl'; |
|
break; |
|
} |
|
|
|
@unlink($file); |
|
|
|
$rubric_id = $AVE_DB->Query("SELECT rubric_id FROM " . PREFIX . "_rubric_fields WHERE Id = '".$id."'")->GetCell(); |
|
|
|
$AVE_DB->Query(" |
|
UPDATE |
|
" . PREFIX . "_rubrics |
|
SET |
|
rubric_changed_fields = '" . time() . "' |
|
WHERE |
|
Id = '" . intval($rubric_id) . "' |
|
"); |
|
|
|
$AVE_DB->clearCache('rub_' . $rubric_id); |
|
$this->clearChanges(); |
|
|
|
header('Location:' . get_referer_link()); |
|
exit; |
|
} |
|
|
|
|
|
function clearTemplates($rubric_id) |
|
{ |
|
|
|
} |
|
|
|
|
|
function clearChanges() |
|
{ |
|
$cache_file = BASE_DIR . '/tmp/cache/sql/rubrics/all/rubrics.cahnges'; |
|
unlink($cache_file); |
|
} |
|
} |
|
?>
|