Наследование свойств от родительского элемента — различия между версиями

Материал из Umicms
Перейти к:навигация, поиск
 
(не показаны 3 промежуточные версии 2 участников)
Строка 1: Строка 1:
При наполнении сайта, может возникнуть необходимость в автоматическом наследовании свойств родительского элемента. Для реализации наследования свойств родительского элемента напишем кастомный обработчик события, который будет наследовать свойство "Исключить из поиска".
+
'''Актуально для версии 20'''
Для начала, напишем вызов обработчика по событию создания элемента в файле ~/classes/modules/content/custom_events.php
+
 
 +
== Задача ==
 +
При создании страниц сайта автоматически наследовать какие-либо свойства родительской страницы.
 +
== Решение ==
 +
 
 +
Для реализации наследования свойств родительского элемента напишем кастомный обработчик события, который будет наследовать свойство "Исключить из поиска".
 +
Для начала, напишем вызов обработчика по событию создания элемента в файле '''~/classes/components/content/custom_events.php'''
 
<source lang="php">
 
<source lang="php">
 
<?php
 
<?php
Строка 6: Строка 12:
 
?>
 
?>
 
</source>
 
</source>
А вот и сам код обработчика, который нужно поместить в файл ~/classes/modules/content/__custom_adm.php после строки //TODO: Write here your own macroses
+
А вот и сам код обработчика, который нужно поместить в файл ~/classes/components/content/customAdmin.php <source lang="php">
<source lang="php">
+
public function inheritance_properties(iUmiEventPoint $oEventPoint) {
<?php
+
if ($oEventPoint->getMode() != "after"){
public function inheritance_properties(iUmiEventPoint $oEventPoint) {
+
return;
if ($oEventPoint->getMode() === "after"){
+
}
$object = $oEventPoint->getRef("element");
+
$id=$object->id;
+
$object = $oEventPoint->getRef("element");
$parentId=$object->getParentId();
+
$hierarchy = umiHierarchy::getInstance();
+
$id = $object->id;
$parent=$hierarchy->getElement($parentId);
+
$parentId = $object->getParentId();
$object=$hierarchy->getElement($id);
+
$value=$parent->getValue('is_unindexed');
+
$hierarchy = umiHierarchy::getInstance();
$object->setValue('is_unindexed',$value);
+
$parent=$hierarchy->getElement($parentId);
$object->commit();
+
$object=$hierarchy->getElement($id);
return true;
+
}
+
$value=$parent->getValue('is_unindexed');
}
+
?>
+
$object->setValue('is_unindexed',$value);
 +
$object->commit();
 +
return true;
 +
}
 
</source>
 
</source>
здесь is_unindexed - идентификатор поля "Исключить из поиска".
+
 
После занесения записи об этом методе в файл ~/classes/modules/content/permissions.custom.php он будт работать для всех пользователей, которые имеют доступ к панели администрирования.
+
Здесь is_unindexed - идентификатор поля "Исключить из поиска".
<p>
+
После занесения записи об этом методе в файл '''~/classes/components/content/permissions.custom.php''' он будет работать для всех пользователей, которые имеют доступ к панели администрирования.
Данный функционал был проверен на работоспособность в версии системы 2.8.5.1.
+
 
</p>
 
 
[[Категория: API]]
 
[[Категория: API]]

Текущая версия на 14:49, 27 мая 2019

Актуально для версии 20

Задача

При создании страниц сайта автоматически наследовать какие-либо свойства родительской страницы.

Решение

Для реализации наследования свойств родительского элемента напишем кастомный обработчик события, который будет наследовать свойство "Исключить из поиска". Для начала, напишем вызов обработчика по событию создания элемента в файле ~/classes/components/content/custom_events.php

<?php
	new umiEventListener('systemCreateElement', 'content', 'inheritance_properties');
?>

А вот и сам код обработчика, который нужно поместить в файл ~/classes/components/content/customAdmin.php

public function inheritance_properties(iUmiEventPoint $oEventPoint) {
	if ($oEventPoint->getMode() != "after"){
		return;
	}			
			
	$object = $oEventPoint->getRef("element");
			
	$id = $object->id;			
	$parentId = $object->getParentId();
			
	$hierarchy = umiHierarchy::getInstance();
	$parent=$hierarchy->getElement($parentId);
	$object=$hierarchy->getElement($id);
			
	$value=$parent->getValue('is_unindexed');
			
	$object->setValue('is_unindexed',$value);	
	$object->commit();	
	return true;
}

Здесь is_unindexed - идентификатор поля "Исключить из поиска". После занесения записи об этом методе в файл ~/classes/components/content/permissions.custom.php он будет работать для всех пользователей, которые имеют доступ к панели администрирования.