Разработка сайтов на MODX Revolution + phpTemplates + modxSmarty
Так как все больше программистов пытаются взять на вооружение объявленную технологию, и методика боле менее обкаталась и приняла четкие очертания, пишу пошаговую инструкцию как и с чего начать. Весь процесс я заснял и выкладываю в виде подробного часового ролика. Но кому лень смотреть, или формат не удобный/скучный, расписываю здесь пошаговую инструкцию. 1. Устанавливаем чистую MODX Revolution. 2. Добавляем новый источник пакетов.
Как минимум пакет modxSite не лежит в официальном репозитории modx.com, по этому его предстоит скачать с https://rest.modxstore.ru/extras/. ? 3. Устанавливаем пакеты: Ace modxSDK modxSite (из https://rest.modxstore.ru/extras/) modxSmarty shopModx (из него нам понадобятся только процессоры для выборки документов) phpTemplates Console getPage 4. Создаем базовый контроллер.
Для этого создаем статический MODX-шаблон. Файл шаблона должен иметь расширение .php (к примеру, base.php) и запишем в шаблон следующий код: Таким образом мы получим универсальный контроллер, и в дальнейшем на большинство шаблонов его будет вполне достаточно. И если вам надо создать новый MODX-шаблон просто с целью привязать новые TV-параметры, вы также указываете этот статический файл base.php в качестве источника кода для шаблона, и ничего дополнительно делать не придется. А если надо будет и отображение изменить (конечный шаблон), то просто в свойствах MODX-шаблона указываете новую настройку tpl сназванием файла-шаблона. (Если здесь не понятно, лучше посмотреть видео). По поводу кеширования MODX-шаблонов: если у шаблона нет настройки phptemplates.non-cached=true, то при повторном заходе на страницу шаблон не будет опять обрабатываться, а просто будет отдаваться код из кеша страницы. Если надо отключить кеширование шаблона, то просто в шаблоне создаем такую настройку, и устанавливаем в true. А иначе придется после каждого изменения в коде шаблона сбрасывать кеш сайта (то есть это как правило надо на время программинга или отладки). ? Важно создать плагин на событие OnHandlerRequest, но с рангом очередности выше плагина modxSmarty. Это чтобы в Smarty-шаблонах переменная $template_url формировала путь к папке публичной части шаблона. <?php
switch($modx->event->name){
case 'OnHandleRequest':
if($modx->context->key == 'mgr'){
return;
}
//URL к файлам шаблона (css, js, images etc.)
$modx->smarty->assign('template_url',
$modx->getOption('modxSite.template_url').$modx->getOption('modxSmarty.template').'/');
break;
} Код вызова процессора через консоль (может использоваться в сниппетах и плагинах): <?php
print '
';
$modx->setLogLevel(3);
$namespace = 'shopmodx';
if(!$response = $modx->runProcessor('web/getdata',
array(
// Параметры
), array(
'processors_path' => $modx->getObject('modNamespace', $namespace)->getCorePath().'processors/',
))){
print "Не удалось выполнить процессор";
return;
}
print_r($response->getResponse()); Код общего процессора для выборки документов с условиями, расширяющего базовый процессор из shopModx-а. <?php
require_once MODX_CORE_PATH .'components/shopmodx/processors/web/getdata.class.php';
class modWebGetdataProcessor extends ShopmodxWebGetDataProcessor{
public function initialize(){
$this->setDefaultProperties(array(
'sort' => "{$this->classKey}.menuindex",
'dir' => 'ASC',
'showhidden' => false,
'showunpublished' => false,
'getPage' => false,
'limit' => 10,
'page' => !empty($_REQUEST['page']) ? (int)$_REQUEST['page'] : 0
));
if($page = $this->getProperty('page') AND $page > 1 AND $limit = $this->getProperty('limit', 0)){
$this->setProperty('start', ($page-1) * $limit);
}
return parent::initialize();
}
public function prepareQueryBeforeCount(xPDOQuery $c) {
$c = parent::prepareQueryBeforeCount($c);
$where = array(
'deleted' => false,
);
if(!$this->getProperty('showhidden', false)){
$where['hidemenu'] = 0;
}
if(!$this->getProperty('showunpublished', false)){
$where['published'] = 1;
}
$c->where($where);
return $c;
}
public function outputArray(array $array, $count = false) {
if($this->getProperty('getPage') AND $limit = $this->getProperty('limit')){
$this->modx->setPlaceholder('total', $count);
$this->modx->runSnippet('getPage@getPage', array(
'limit' => $limit,
));
}
return parent::outputArray($array, $count);
}
}
return 'modWebGetdataProcessor'; P.S. Здесь очень сложно расписать все, так что кому интересно, все-таки сделайте усилие и посмотрите видеоролик. Там основное рассказано и показано в первые 30 минут. Вторая часть ролика может и очень нудная, но там есть неплохие примеры по использованию всего этого дела.
И не стесняйтесь, задавайте вопросы.