Добавление страниц через клиентскую часть — различия между версиями
VITL' (обсуждение | вклад) |
VITL' (обсуждение | вклад) |
||
Строка 49: | Строка 49: | ||
} | } | ||
</source> | </source> | ||
+ | Если вы используете систему версии 2.7.4 и ниже, то строку: | ||
+ | <pre> | ||
+ | $buffer = outputBuffer::current('HTTPOutputBuffer'); | ||
+ | </pre> | ||
+ | необходимо удалить. | ||
+ | |||
Необходимо в той же папке создать файл permissions.custom.php с таким содержанием: | Необходимо в той же папке создать файл permissions.custom.php с таким содержанием: | ||
+ | <pre> | ||
<?php | <?php | ||
− | + | $permissions = Array('main' => Array('addNewObject')); | |
?> | ?> | ||
− | + | </pre> | |
Макросом %data getCreateForm(23,'umi')% на страницу добавляем форму для добавления страницы. Макрос использует шаблон tpls/data/reflection/umi.tpl . Основной блок reflection_block можно сделать таким: | Макросом %data getCreateForm(23,'umi')% на страницу добавляем форму для добавления страницы. Макрос использует шаблон tpls/data/reflection/umi.tpl . Основной блок reflection_block можно сделать таким: | ||
<source lang="php"> | <source lang="php"> |
Версия 13:03, 9 декабря 2010
Используем кастомный макрос, который пропишем в файле classes/modules/data/__custom.php
public function addNewObject() {
$hierarchy = umiHierarchy::getInstance();
$hierarchyTypes = umiHierarchyTypesCollection::getInstance();
$objectTypes = umiObjectTypesCollection::getInstance();
$cmsController = cmsController::getInstance();
$parent_id = (int) getRequest('parent');
if (!$object_type_id = (int) getRequest('param0')) return "";
$title = htmlspecialchars(trim(getRequest('title')));
$parentElement = $hierarchy->getElement($parent_id);
$tpl_id = $parentElement->getTplId();
$domain_id = $parentElement->getDomainId();
$lang_id = $parentElement->getLangId();
$hierarchy_type_id = $objectTypes->getType($object_type_id)->getHierarchyTypeId();
$element_id = $hierarchy->addElement($parent_id, $hierarchy_type_id, $title, $title, $object_type_id, $domain_id, $lang_id, $tpl_id);
permissionsCollection::getInstance()->setDefaultPermissions($element_id);
$element = $hierarchy->getElement($element_id, true);
(getRequest('active'))?$element->setIsActive(true):$element->setIsActive(false);
$element->setIsVisible(false);
$element->setName($title);
$data = $cmsController->getModule("data");
if($data instanceof def_module) {
$object_id = $element->getObjectId();
$data->saveEditedObject($object_id, true);
}
$element->getObject()->commit();
$element->commit();
$parentElement->setUpdateTime(time());
$parentElement->commit();
$referer_url = getServer('HTTP_REFERER');
$buffer = outputBuffer::current('HTTPOutputBuffer');
$ini = cmsController::getInstance()->getModule("content");
$ini->redirect($referer_url);
}
Если вы используете систему версии 2.7.4 и ниже, то строку:
$buffer = outputBuffer::current('HTTPOutputBuffer');
необходимо удалить.
Необходимо в той же папке создать файл permissions.custom.php с таким содержанием:
<?php $permissions = Array('main' => Array('addNewObject')); ?>
Макросом %data getCreateForm(23,'umi')% на страницу добавляем форму для добавления страницы. Макрос использует шаблон tpls/data/reflection/umi.tpl . Основной блок reflection_block можно сделать таким:
<form method="post" action="%pre_lang%/data/addNewObject/23/" enctype="multipart/form-data" >
Название страницы: <input type="text" name="title" />
<table>
%groups%
<table>
<input style="visibility:hidden" type="checkbox" checked="checked" name="parent" value="42" />
<input style="visibility:hidden" type="checkbox" checked="checked" name="active" value="0" />
<input type="submit" />
</form>
Остальные блоки стандартного содержания. В данном примере используется добавление страницы типа Новость, id=23 (Модуль Шаблоны данных). Id страницы которая будет являться родительской по отношению к создаваемой прописана в input’e с name="parent". Делать ли страницу активной, после создания, определяется в: name="active" , 0 – неактивная, 1 – активная.