Поступил тут один вопрос, который я хотел бы разобрать в паблике поподробней (к слову: задавайте такие вопросы не в личку, а в паблик. Ничего зазорного здесь нет, а материал будет полезен и другим). Вопрос и ответ под катом. Вопрос: Пытаюсь разобраться с написанием процессоров для использования с modxsmarty, че-то не клеится. Взял Ваш getList шаблон из shopmodx (ShopmodxWebGetlistProcessor), немного его модифицировал: class SiteNewsGetlistProcessor extends modObjectGetListProcessor { public $classKey = 'modResource'; public $defaultSortField = 'publishedon'; public $defaultSortDirection = 'DESC'; public $objectType = 'modResource'; protected $total = 0;

public function prepareQueryBeforeCount(xPDOQuery $c) { $p=0; if(isset($scriptProperties['parent'])) $p=$scriptProperties['parent']; $c->where(array( 'parent' => $p )); $c->limit(8); return $c; } . . . Дальше все как у Вас. В консоли отрабатывается, получаю ресурсы, но процессор не видит передаваемый параметр parent: <?php $ns=$modx->getObject('modNamespace','site'); $p=$ns->getCorePath(); $response=$modx->runProcessor('getnews', array('parent'=>4,),array('processors_path'=>$p)); print_r($response->getResponse()); выдает результат с $p=0. Это первая проблема. А вторая — вызываю процессор в smarty: {processor action="getnews" ns="site" assign=result} <ul class="carousel2"> {if $result.success} {foreach $object.object as $object} {include file="news.tpl"} {/foreach} {else} <li> <strong>error {$result.success}</strong> </li> {/if} Выводится «error» Если вместо error {$result.success} пишу error {$result}, то выводит «error Array». Насколько я понимаю, smarty почему-то не видит элементы массива (например $result.success). И подскажите пожалуйста, как я могу разрешить исполнение блоков {php} в modxsmarty? Ответы: 1. Следите за переменными. Переменные просто так ни от куда не берутся. Вот кусочек кода: public function prepareQueryBeforeCount(xPDOQuery $c) { $p=0; if(isset($scriptProperties['parent'])) А откуда здесь взялась переменная $scriptProperties? Ее здесь нет. Это раньше (в неклассовых процессорах) была переменная $scriptProperties. Но она создавалась MODX-ом в функции $modx->runProcessor(), то есть передавалась дальше в процессор. А в классных процессорах этого нет. Все параметры процессора находятся в элементе array $this->properties, и для работы с этой переменной есть методы $this->getProperties(), $this->getProperty(), $this->stProperties() и $this->setProperty(); Вот если бы создали эту переменную вот так, то у вас бы все заработало: public function prepareQueryBeforeCount(xPDOQuery $c) { $p=0; $scriptProperties = $this->getProperties(); if(isset($scriptProperties['parent'])) Но это не по фэн-шую. Правильно использовать методы по умолчанию. К примеру так: public function prepareQueryBeforeCount(xPDOQuery $c) { // Второй параметр 0 - это значение по умолчанию $p = $this->getProperty('parent', 0); $c->where(array( 'parent' => $p )); $c->limit(8); return $c; } . . . А еще правильней делать вот так: // Эта функция вызывается в первых рядах запуска процессора public function initialize(){ // Устанавливаем значения по умолчанию // Не перетирает уже имеющиеся свойства $this->setDefaultProperties(array( 'parent' => 0, )); return parent::initialize(); }

public function prepareQueryBeforeCount(xPDOQuery $c) { $c->where(array( 'parent' => $this->getProperty('parent'), )); $c->limit(8); return $c; } . . . Вот так у вас и важные переменные сразу будет видно, и дефолтовые значения указаны, и их можно будет перегрузить как на уровне входящих параметров, так и на уровне расширяющих процессоров. 2. Тоже следите за переменными: {processor action="getnews" ns="site" assign=result} <ul class="carousel2"> {if $result.success} {foreach $object.object as $object} {include file="news.tpl"} {/foreach} {else} <li> <strong>error {$result.success}</strong> </li> {/if} Присваиваете переменной result (assign=result), а пытаетесь использовать переменную $object ({foreach $object.object as $object}) В данном случае правильно {foreach $result.object as $object}. Ответ 3. И подскажите пожалуйста, как я могу разрешить исполнение блоков {php} в modxsmarty? Это не зависит уже от самого modxSmarty. Это же все на совести Smarty, так что все должно работать (читайте манны Smarty). UPD: Выводится «error» Если вместо error {$result.success} пишу error {$result}, то выводит «error Array». $result.success — это логическое. Оно возвращает только true или false (если никто не будет нарушать стандарта). Логическое true просто так в виде текста не выводится. А {$result} — это равносильно print $array. print не выводит содержимого массива, а просто пишет, что это массив (array). Если хотите четко видеть какой ответ возвращается, то выводите весь ответ так: <pre> {print_r($result)} </pre>

Интересный взгляд Евгения aka Agel_Nash на развивающийся рынок MODX-репозиториев.

Так как все больше программистов пытаются взять на вооружение объявленную технологию, и методика боле менее обкаталась и приняла четкие очертания, пишу пошаговую инструкцию как и с чего начать. Весь процесс я заснял и выкладываю в виде подробного часового ролика. Но кому лень смотреть, или формат не удобный/скучный, расписываю здесь пошаговую инструкцию. 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 '<pre>'; $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 минут. Вторая часть ролика может и очень нудная, но там есть неплохие примеры по использованию всего этого дела. И не стесняйтесь, задавайте вопросы.

Ребята реально классно делают! Сделали нам для одного проекта довольно много 3D-объектов. На выходных выложу их на сайте и напишу топик.

Предлагаем Вашему вниманию услуги 3D-фотосъемки для онлайн-каталогов! Съемка предметов с круговым обзором в 360 градусов – новая технология современной цифровой фотографии. 3D-панорама — новшество современной цифровой фотографии, она позволяет воссоздать трехмерное изображение предмета без дорогостоящей отрисовки в 3DMax. 3D-съемка позволяет рассмотреть товар со всех сторон и получить о нем полное представление еще до покупки. Потрясающая объемная картинка создает иллюзию того, что этот предмет вы держите в руках. Ваши клиенты почувствуют себя в магазине, не выходя из дома. Фотосъемка 2-х предметов бесплатно!!! Мы сделаем для вас фотографии желаемого формата и размера без предоплаты: — если качество работ вам не понравится — вы ничего не оплачиваете; Образцы работ можете посмотреть на нашем сайте: 360-view.ru/index.php/krugovaya-s-emka/3d-foto E-mail: studio-360@yandex.ru Тел.: 8 (495) 722-48-45 www.360-view.ru

Пожалуйста :-)

Спасибо! в SDK работать гораздо гораздее! )

Добрый день! Вот незадача… Писал коммент еще ночью, но почему-то его здесь нет. Проблема однозначная: у вас включено сжатие JS в админке. Пока это не победил (некогда было колупаться), так что пока просто отключаете сжатие JS, перегружаете страницу, и все будет работать.

Добрый день. Очень впечатлился модулями modxSmarty, phpTemplates и modxSDK. Скачал, установил, радуюсь. Круто все. Как я люблю. Николай, спасибо за них огромное!!! Но возникла одна проблемка: в редакторе среды SDK я не могу ввести пробел, только TAB, и тогда добавляется либо 4 пробела, либо TAB и несколько пробелов. И если я захожу на уже написанную строку, то при нажатии backspace удаляется символ не перед курсором, а на 2 символа левее. И если открываю при открытом SDK окно документа, то поле контента выводится очень маленьким (около 10х10 символов) Стоит MODX 2.2.8-pl, последние пакеты. На компе установлен PuntoSwitcher, но в остальных окнах MODX он не мешает. Может, сталкивался кто с таким?