[REVO] MODx Revolution Plugin: ChangeTemplate

ChangeTemplate это плагин для MODx Revolution (2.2.0-pl2). Этот плагин является особенно полезным, когда мы должны контролировать, какие Шаблон наследуется детьми в документах родителя.
С ChangeTemplate пользователю не нужно помнить, какой выбрать шаблон, потому что это делается автоматически с помощью плагина.
Нашел на форуме. может кому и пригодится.
1. Установка
Для установки плагина ChangeTemplate перейдите в раздел «Элементы> Plugins> Новый плагин» и создайте:
Имя плагина: ChangeTemplate
Системные события: OnDocFormRender
Код плагина
<?php
/**
* =========================
* ChangeTemplate
* =========================
*
* Plugin for MODX Revolution
* Set which template is inherited by children 
* documents of a certain parent document
*
* Author:
* Marc Loehe (boundaryfunctions)
* marcloehe.de
*
* Modified by:
* Lorenzo Stanco <lorenzo.stanco@gmail.com>
* Lorenzostanco.com
*
* Usage:
*
* 1. Paste this as new plugin and connect it to system event
* 'OnDocFormRender'.
*
* 2. Assign a new TV 'changeTemplate' to each template
* for which you want to define the default children template.
*
* 3. Set the newly created TV to input type "Text" 
*
* 4. Open a document and in the 'changeTemplate' TV type a 
* comma separated list of template IDs.
*
* 5. Have fun!
*
*/
 
// Check Event
if ($modx->event->name == OnDocFormRender && $mode == modSystemEvent::MODE_NEW) {
   
  // Get current document ID
  if ($id = $_REQUEST['id']) {
 
    // Document Chain
    $resources = array($id);
 
    // Get parent ID
    foreach ($modx->getParentIds($id, 10, array('context' => $_REQUEST['context_key'])) as $parentId) {
      if ($parentId) array_push($resources, $parentId);
    }
     
    // Search changeTemplate in the chain
    $level = 0;
    $childTemplates = array();
    foreach ($resources as $resourceId) {
      $resource = $modx->getObject('modResource', $resourceId);
      if ($childTemplatesTV = $resource->getTVValue('changeTemplate')) {
         
        // Create template array for each tree level
        $childTemplates = @explode(',', $childTemplatesTV);
        if (empty($childTemplates)) break;
        foreach ($childTemplates as $k => $v) $childTemplates[$k] = intval(trim($v));
         
        break;
 
      }
 
      $level++;
 
    }
 
    // Set template based on tree level
    if (!empty($childTemplates)) {
      $useTemplate = $childTemplates[$level];
      if (!empty($useTemplate)) {
        
        // Set default template
        if (isset($modx->controller)) {
          $modx->controller->setProperty('template', $useTemplate);
        } else { // modX < 2.2.0
          $_REQUEST['template'] = $useTemplate;
        }
 
      }
    }
 
  }
 
}

Теперь создайте TV
TV Name: changeTemplate
TV Input Options: Text
TV Template Access: Указать в каких шаблонах, мы используем этот плагин
2. Применение:
Этот плагин очень прост в использовании. Давайте предположим, что у нас есть шаблон 1 (1), Шаблон 2 (4), Шаблон 3 (5), Шаблон 4 (6), и шаблона 5 (7), как показано в следующем скриншоте

Первым делом переходим к ресурсам, откройте «Home» документ (или любого другой документ) и установите значение changeTemplate значения «4,5,6,7». Эти номера идентификаторов наших шаблонов. Вот скриншот моего «changeTemplate» ТВ:

Как только «Home» документ сохраняется, мы можем создавать вложенные документы из «Home», и плагин «ChangeTemplate» позаботится о выборе просил шаблона для каждого дерева уровне, так:
Дерево Уровень 2 => Шаблон 2 (ID 4)
Дерево Уровень 3 => Шаблон 3 (ID 5)
Дерево Уровень 4 => Шаблон 4 (ID 6)
Дерево Уровень 5 => Шаблон 5 (ID 7)

Вот и все! Вы можете найти более подробную информацию об этом плагине на этой ветке форума.

1 комментарий

avatar
Спасибо большое. Один из тех плагинов, которые есть в моей личной сборке.
Только зарегистрированные и авторизованные пользователи могут оставлять комментарии.