Добавление страниц через клиентскую часть — различия между версиями

Материал из Umicms
Перейти к:навигация, поиск
(Новая страница: « category:Описание модулей и макросов Используем кастомный макрос, который пропишем в файле…»)
 
Строка 37: Строка 37:
 
$data->saveEditedObject($object_id, true);
 
$data->saveEditedObject($object_id, true);
 
}
 
}
 +
 
$element->getObject()->commit();
 
$element->getObject()->commit();
 
$element->commit();
 
$element->commit();
Строка 42: Строка 43:
 
$parentElement->commit();
 
$parentElement->commit();
  
if($element->getIsActive()) {
+
$referer_url = getServer('HTTP_REFERER');           
$referer_url = $hierarchy->getPathById($element_id);
+
$buffer = outputBuffer::current('HTTPOutputBuffer');  
} else {
+
$ini = cmsController::getInstance()->getModule("content");  
$referer_url = getServer('HTTP_REFERER');
+
$ini->redirect($referer_url);
}
 
$this->redirect($referer_url);
 
 
}
 
}
 
</source>
 
</source>

Версия 17:43, 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);
}

Необходимо в той же папке создать файл 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 – активная.