Шаблон – содержит общую верстку страницы со структурой и дизайном. Также в нем определяются места для вывода динамического содержимого. Для каждого документа можно выбрать свой шаблон.
Параметры (TV) – дополнительные параметры, которые подключаются к шаблону. Параметры могут быть разных типов (текст, ссылка, файл, дата, число и т.д.). Более подробно о типах ждите в следующих статьях.
Чанк – маленький шаблон, который может использоваться как просто для вывода какого-то содержимого (телефона на всех страницах), так и для обработки (шаблон отправляемого письма FormIt, шаблон каталога выводимого pdoPage и т.д.). Таким образом, вид (представление) информации отделяется от места обработки и легко управляется.
Сниппет – код для обработки информации. Анализируют полученную информацию (например, сообщение пользователя) и предоставляют результат (например, отправляют сообщение по почте, а пользователю показывают сообщение о результате). Сниппеты формируют меню (pdoMenu), выводят списки статей с разбиением на страницы (pdoPage), строят формы (FormIt). Для вывода используют Чанки.
Плагин – код, который запускается при наступлении какого-то события. Например, подсвечивает искомые слова (Search Highlighting) при переходе со страницы поиска. Событий много и их рассмотрение стоит отдельной статьи
Для вывода динамических данных используются специальные теги.
[[++site_name]] – название сайта
[[++base_url]] или [[++site_url]] – адрес сайта (http://modx.ru)
[[++modx_charset]] – используемая кодировка
[[++cultureKey]] - текущий ключ язика
[^qt^] – время на запросы к базе данных
[^q^] – запросов к базе данных
[^p^] – время на работу PHP скриптов
[^t^] – общее время на генерацию страницы
[^s^] – источник содержимого (база или кэш)
[[*pagetitle]] – заголовок документа
[[*longtitle]] – расширенный заголовок документа
[[*description]] – описание документа
[[*introtext]] – аннотация документа
[[*content]] – содержимое документа
[[*alias]] – псевдоним документа
[[*id]] – идентификатор (номер) документа
[[*pub_date]] – дата публикации дкоумента
[[*unpub_date]] – дата завершения публикации
[[*createdby]] – Идентификатор пользователя создавшего документ
[[*createdon]] – Дата создания документа
[[*editedby]] – Идентификатор пользователя редактировавшего документ
[[*editedon]] – Дата редактирования документа
[[~идентификатор]] – URL указанного документа
[[*type]] – вариант (документ, папка или ссылка)
[[*contentType]] – тип содержимого (например, text/html)
[[*published]] – опубликован ли документ (1|0)
[[*parent]] – номер (ID) родительского документа
[[*isfolder]] – является ли документа папкой (1|0)
[[*richtext]] – используется ли при редактировании документа визуальный редактор
[[*template]] – номер (ID) используемого шаблона для документа
[[*menuindex]] – порядковый номер отображения в меню
[[*cacheable]] – Кэшируется ли документ (1|0)
[[*deleted]] – Документ удален (1|0)
[[*deletedby]] – Идентификатор пользователя удалившего документ
[[*menutitle]] – Заголовок меню. Если не используется, то заголовок документа
[[*donthit]] – Слежение за количеством посещений отключено (1|0)
[[*haskeywords]] – Документ содержит ключевые слова (1|0)
[[*hasmetatags]] – Документ имеет метатеги (1|0)
[[*privateweb]] – Документ входит в частную группу пользовательских документов (1|0)
[[*privatemgr]] – Документ входит в частную группу менеджерских документов (1|0)
[[*content_dispo]] – Вариант выдачи содержимого (1 — для отображения | 0 — для скачивания)
[[*hidemenu]] – Документ не отображается в меню (1|0)
[[*НазваниеПараметраTV]] – выводит значение параметра в документе.
[[$НазваниеЧанка]] – возвращает содержимое чанка.
[[НазваниеСниппета]] – возвращает результат работы сниппета. Также можно передавать сниппету дополнительные параметры,
перечисляя их при вызове — [[НазваниеСниппета? &параметр1=значение1
&параметр2=значение2
&параметрN=значениеN
]]
[[+НазваниеПеременной]] – встречается в чанках, которые используются для обработки (Ditto, eForm и т.д.).
После обработки вместо них вставляются значения. Таким образом, это тоже вроде мини-языка, но для сниппетов.
-
На самом деле есть два варианта вызова сниппета:
[[НазваниеСниппета]] – кэшируемый вызов сниппета
[[! НазваниеСниппета!]] – некэшируемый вызов сниппета -
При использовании дополнительных параметров в сниппете нужно убедиться, что запись не разбивается переносом строки. Если это так, то сниппет откажется работать.
Где использовать
Все очень гармонично используется друг с другом.
В шаблонах можно использовать параметры TV, сниппеты и чанки.
В чанках можно вызывать сниппеты, параметры TV и другие чанки.
В сниппетах можно вызывать вообще все, но через PHP.
В конечном счете вам вернется итоговый результат обработки всех сниппетов/чанков/параметровTV.
System Setting: [[++SettingName]]
TV/current fields name: [[*fieldName/TvName]]
Link tag: [[~PageId? ¶mName=value
]]
Placeholder: [[+PlaceholderName]]
Вывод только папок с первой вложеностю
[[pdoMenu?
&parents=`0`
&level=`1`
&where=`{"isfolder":"1"}`
]]
$modx->resource; // Текущий ресурс
$modx->user; // Текущий пользователь
$modx->getOption('SettingName'); // eg site_start
$array = [ 'a' => 'b' ];
Примери получения данних
$modx->getOption('a', $array, 'default' ); // 'b'
$modx->getOption('b', $array, 'default' ); // 'default'
$elementName = '[SnippetName]';
$modx->log(modX::LOG_LEVEL_ERROR, $elementName.' Could not do something.');
// also: LOG_LEVEL_DEBUG, LOG_LEVEL_INFO, LOG_LEVEL_WARN
$modx->setLogTarget('FILE'); // or ECHO
$target = array(
'target' => 'FILE',
'options' => array(
'filename' => 'path_to_file'),
);
$modx->log(xPDO::LOG_LEVEL_ERROR, 'Error Message', $target);
$modx->setDebug(E_ALL & ~E_NOTICE); // sets error_reporting to everything except NOTICE remarks
$modx->setLogLevel(modX::LOG_LEVEL_DEBUG);
trigger_error('...', E_USER_ERROR);
$modx->getChunk('ChunkName');
foreach ($docs as $doc) {
$output .= $modx->getChunk('teaserTpl', $doc->toArray() );
}
return $output;
class MyClass {
function __construct($modx, $scriptProperties) {
$this->modx =& $modx;
$this->props =& $scriptProperties;
}
public function init() {
$this->size = $this->props['size'];
$this->color = $this->props['color'];
}
}
$id = $modx->resource->get('id');
$resource = $modx->getObject('modResource', array('pagetitle'=>'MyDocument')); // with properties
$resource = $modx->getObject('modResource', $resourceID); // with a document id
$output = '<p>Document:' . $resource->get('longtitle') . '</p>';
$output .= '<p>Content:' . $resource->get('content') . '</p>';
$resource = $modx->getObject('modResource', $resourceID); // with a document id
$resource->set('template', 7);
$resource->save();
$resources = $modx->getCollection('modResource',
array('published'=>'1','deleted'=>'0'));
foreach($resources as $resource) {
$output .= '<div class="resource"><p>Document:' . $resource->get('longtitle') . '</p>';
$output .= '<p>Content:' . $resource->get('content') . '</p></div>';
}
$parent = $modx->resource->getOne('Parent');
return $parent->get('pagetitle');
$children = $modx->resource->getMany('Children');
foreach ($children as $child) {
$output .= '<p>' . $child->get('pagetitle') . '</p>';
}
$tv = $modx->getObject('modTemplateVar',array('name'=>'tvName')); // get the required TV object by name (or id)
$tv->setValue($modx->resource->get('id'), $newValue); // set the new value and save it
$tv->save();
$results = array();
$tvs = $modx->getCollection(
'modTemplateVar',
array("`name` IN (
'image',
'imageClass',
'imageAlt',
'imageCaption'
)")
);
foreach ($tvs as $tv) {
$results[$tv->get('name')] = (empty($processTVs) ? $tv->getValue($resourceId) : $tv->renderOutput($resourceId));
}
return $modx->getChunk('Picture.tpl',$results);
$obj = $modx->getObject('modResource', array('name'=>'MyDoc'));
$id = $obj->get('id');
$tvs = $obj->getMany('TemplateVars');
foreach ($tvs as $tv) {
$rawValue = $tv->getValue($id);
$processedValue = $tv->renderOutput($id);
}
$users = $modx->getCollection('modUser',
array('active'=>'1'));
foreach ($users as $user) {
$output .= '<p>Username: ' . $user->get('username') . '</p>';
}
return $output;
$user = $modx->resource->getOne('CreatedBy');
return $user->get('username');
$resourceIds = array('12, 23, 32, 45');
foreach ($resourceIds as $id) {
$resource = $modx->getObject('modResource',$id);
$resource->set('published', '1');
$resource->save();
}
getObject - get one object/table row
getCollection - get many objects/table rows
getOne - get one related object
getMany - get many related objects
getCollectionGraph - get many objects and their related objects
$object->get('fieldName');
$object->toArray();
foreach ($modx->getIterator('modResource', array('parent' =>15)) as $res) { $res->set('template',5); $res->save(); }
$sql = 'SELECT * FROM `'.$modx->getOption(xPDO::OPT_TABLE_PREFIX).'site_htmlsnippets`';
$result = $modx->query($sql);
if (!is_object($result)) {
return 'No result!';
}
else {
while ($row = $q_chunks->fetch(PDO::FETCH_ASSOC))
// do something: $row['name'];
}
}
modResource
msProduct
msProductData
modSystemSetting
modContext
// first, get the email with the placeholders in it replaced by the snippet call.
// (Note the properties in the snippet call are in the array $scriptProperties.
// http://api.modx.com/revolution/2.1/_model_modx_mail_modmail.class.html
$message = $modx->getChunk('myEmail',$scriptProperties);
/* now load modMail, and setup options */
$modx->getService('mail', 'mail.modPHPMailer');
$modx->mail->set(modMail::MAIL_BODY,$message);
$modx->mail->set(modMail::MAIL_FROM,$scriptProperties['fromEmail']);
$modx->mail->set(modMail::MAIL_FROM_NAME,$scriptProperties['fromName']);
$modx->mail->set(modMail::MAIL_SENDER,$scriptProperties['fromName']);
$modx->mail->set(modMail::MAIL_SUBJECT,$scriptProperties['subject']);
$modx->mail->address('reply-to',$scriptProperties['fromEmail']);
$modx->mail->setHTML(true);
/* specify the recipient */
$modx->mail->address('to',$scriptProperties['toEmail']);
/* send! */
$modx->mail->send();
$modx->mail->reset();
/* get is Admin */
$modx->user->isMember('Administrator')
_build/ - папка, в которой хранятся скрипты, необходимые для создания транспортного пакета:
_build/build.config.php - конфигурация транспортного пакета;
_build/build.transport.php - сборщик транспортного пакета;
_build/data/ - список сниппетов, чанков и других modElement, которые будут установлены;
_build/includes/functions.php - вспомогательные функции для работы сборщика;
_build/properties/properties.*.php - список свойств сниппета;
_build/resolvers/ - вспомогательные скрипты, запускающиеся на конечном сайте при установке пакета;
core/ - файлы, которые нужны для внутренней логики расширения:
core/components/*/controllers/home.class.php - файл для подготовки страниц админки, который загружает
нужные скрипты и стили;
core/components/*/docs - история изменений, инструкция и лицензия;
core/components//elements/snippets/snippet..php - сниппет расширения;
core/components/*/elements/templates/home.tpl - шаблон админки расширения, в котором выводится список
заказов;
core/components//model//*.class.php - класс RBS;
core/components//model/schema/.mysql.schema.xml - схема для xPDO;
core/components/*/processors/mgr/order/getlist.class/php - скрипт для вывода всех заказов в админке;
assets/ - файлы, которые должны быть доступны снаружи, из интернета:
assets/components/*/js/mgr/widgets/home.panel.js - вывод админки расширения;
assets/components/*/js/mgr/widgets/orders.grid.js - вывод таблицы с заказами.