Получение значений полей у родительских страниц любого уровня — различия между версиями
Stexe (обсуждение | вклад) |
Stexe (обсуждение | вклад) |
||
Строка 4: | Строка 4: | ||
'''Реализация:''' <br/> | '''Реализация:''' <br/> | ||
− | |||
− | |||
Строка 13: | Строка 11: | ||
<source lang="php"> | <source lang="php"> | ||
− | + | public function valueParent($id, $level, $field) { | |
− | + | $hierarchy = umiHierarchy::getInstance(); | |
− | + | if ($idParents = $hierarchy->getAllParents($id)) { | |
− | + | if (!array_key_exists($level, $idParents)) | |
− | + | return ""; | |
− | + | $idParent = $idParents[$level]; | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | if ($field == "url") { | |
+ | $content_inst = cmsController::getInstance()->getModule("content"); | ||
+ | return $content_inst->get_page_url($idParent); | ||
+ | } | ||
+ | if (!$value_field = $hierarchy->getElement($idParent)->getValue($field)) | ||
+ | return ""; | ||
+ | return $value_field; | ||
+ | } | ||
+ | |||
+ | return ""; | ||
+ | } | ||
</source> | </source> | ||
− | + | ||
+ | Макрос '''valueParent()''' возвращает значение поля с идентификатором '''$field''', страницы которая находится на $'''level''' уровне вложенности в иерархии и является родительской по отношению к странице с id = '''$id'''. | ||
+ | |||
+ | <h2>TPL-шаблонизатор</h2> | ||
+ | |||
Пример вызова макроса: %custom valueParent(%pid%, 2, h1)% | Пример вызова макроса: %custom valueParent(%pid%, 2, h1)% | ||
+ | <br/>Параметр '''$id''': <br/> | ||
%pid% - В данном случае id текущей страницы, относительно которой будем брать | %pid% - В данном случае id текущей страницы, относительно которой будем брать | ||
родительскую страницу. | родительскую страницу. | ||
− | + | <br/>Параметр '''$level''': <br/> | |
2 - уровень вложенности родительской страницы от корня сайта. | 2 - уровень вложенности родительской страницы от корня сайта. | ||
1 - самый верхний уровень (основные родительские страницы в структуре сайта) | 1 - самый верхний уровень (основные родительские страницы в структуре сайта) | ||
− | + | <br/>Параметр '''$field''': <br/> | |
h1 - идентификатор поля, значение которого надо получить. | h1 - идентификатор поля, значение которого надо получить. | ||
Если третьим параметром передан "url", то будет получена ссылка на страницу | Если третьим параметром передан "url", то будет получена ссылка на страницу | ||
родителя. | родителя. | ||
+ | |||
+ | <h2>XSLT-шаблонизатор</h2> |
Версия 05:50, 27 апреля 2014
Актуально для версии 2.9.6
Задача: Реализовать функционал получения значения полей родительских страниц любого уровня вложенности.
Реализация:
В файл ~classes/modules/custom.php добавим определение custom макроса valueParent():
public function valueParent($id, $level, $field) {
$hierarchy = umiHierarchy::getInstance();
if ($idParents = $hierarchy->getAllParents($id)) {
if (!array_key_exists($level, $idParents))
return "";
$idParent = $idParents[$level];
if ($field == "url") {
$content_inst = cmsController::getInstance()->getModule("content");
return $content_inst->get_page_url($idParent);
}
if (!$value_field = $hierarchy->getElement($idParent)->getValue($field))
return "";
return $value_field;
}
return "";
}
Макрос valueParent() возвращает значение поля с идентификатором $field, страницы которая находится на $level уровне вложенности в иерархии и является родительской по отношению к странице с id = $id.
TPL-шаблонизатор
Пример вызова макроса: %custom valueParent(%pid%, 2, h1)%
Параметр $id:
%pid% - В данном случае id текущей страницы, относительно которой будем брать
родительскую страницу.
Параметр $level:
2 - уровень вложенности родительской страницы от корня сайта.
1 - самый верхний уровень (основные родительские страницы в структуре сайта)
Параметр $field:
h1 - идентификатор поля, значение которого надо получить.
Если третьим параметром передан "url", то будет получена ссылка на страницу
родителя.