Наумов Алексей

Наумов Алексей

С нами с 31 марта 2013; Место в рейтинге пользователей: #13
Наумов Алексей
05 ноября 2014, 13:16
0
В сторону MIGx посмотрите. Либо просто MIGx, который будет в json хранить, либо MIGxdb, что бы в отдельных таблицах хранить
Наумов Алексей
05 ноября 2014, 08:51
0
Сделайте видео, пожалуйста =) 850 км до вас же)
Наумов Алексей
05 ноября 2014, 08:49
0
Может там еще id было? или какой нибудь атрибут ms2_..., который вы потеряли?
Наумов Алексей
30 октября 2014, 11:26
0
0. Документация
1. Смотреть исходный код сниппетов
2. Смотреть стандартные чанки, которые идут вместе со сниппетом
3. Собственный опыт =)
4. Спрашивать в особо сложных случаях

а, ну и как бы большинство плейсхолдеров соответствуют полям ресурса, такие как pagetitle, menutitle, introtext и т.д.
Наумов Алексей
29 октября 2014, 19:50
+1
1. Да, вообще там все вроде понятно, посмотрите как в Tickets все прописано.
2. [[!Jevix@myparams? .....]]
Наумов Алексей
29 октября 2014, 11:20
0
Да вроде так должен…

Если не цепляется — может в консоли ошибки какие, или изменил/удалил id поля?..
Наумов Алексей
28 октября 2014, 13:18
0
«Ресурсы» — список ресурсов с данным шаблоном.
Проблем при наличии большого количества (>1 000, > 20 000) ресурсов не будет?..
Наумов Алексей
28 октября 2014, 10:16
+1
Ну вместо

foreach ($Widget->data->images as $key=>$item){
	$imagesArray[] ='<a href="'.$item->link.'" class="image" target="_blank"><img src="'.$item->large.'" alt="" /></a>';
}
делай

foreach ($Widget->data->images as $key=>$item){
	$imagesArray[] = $modx->getChunk($tpl, array('link' => $item->link, 'src' => $item->large));
}
что-то не получается?
Наумов Алексей
27 октября 2014, 09:37
1
0
Отвечу сам себе этим комментарием с Хабра: habrahabr.ru/post/240937/#comment_8090731

у меня время на серваке изменилось, все в порядке.
Наумов Алексей
27 октября 2014, 09:17
0
Хм, а что делать с серваком? Виртуальная машина на linode находится, часовой пояс у сайта в настройках — Москва, но время то неверное теперь показывает.
Наумов Алексей
23 октября 2014, 09:46
0
не
[[[[+total_count]]:is=`0`:then=`<p>ничего нет</p>`:else=`<p>есть что-то в корзине...</p>`]]
а
[[+total_count:is=`0`:then=`<p>ничего нет</p>`:else=`<p>есть что-то в корзине...</p>`]]
Наумов Алексей
21 октября 2014, 10:24
0
Попробуй вызвать ms2Gallery, передав параметры: &page=`2` &limit=`5`, если сработает, то и pdoPage должен работать.
Наумов Алексей
21 октября 2014, 10:16
0
А вообще пробовали? Должно работать как часы.
Наумов Алексей
21 октября 2014, 09:40
0
Спасибо!

возможность отключения вкладки галереи для некоторых шаблонов
о да, жду)!
Наумов Алексей
17 октября 2014, 15:46
4
+2
Пример с MIGx db, в общих чертах, код взят с одного из сайтов кусками, и для вашего сайта его надо будет переработать.

1. Настраиваем MIGx

1.1. Создаем таблицы в БД и объекты
— Ставим MIGx, как написано в документации к нему!
Я назвал этот «полукомпонент» xqa, все имена/префиксы делал с этим названием…
— Открываем MIGx в админке, и на первой вкладке создаем package xqa
— берем эту xml
<?xml version="1.0" encoding="UTF-8"?>
<model package="xqa" baseClass="xPDOObject" platform="mysql" defaultEngine="MyISAM" version="1.1">
	<object class="xQa" table="xqa" extends="xPDOSimpleObject" >
	<field key="resource_id" dbtype="int" precision="11" phptype="integer" null="false" default="0" />
	<field key="author" dbtype="varchar" precision="255" phptype="string" null="false" default="" />
	<field key="author_email" dbtype="varchar" precision="255" phptype="string" null="false" default="" />
	<field key="question" dbtype="text" phptype="string" />
	<field key="answer" dbtype="text" phptype="string" />
	<field key="notify" dbtype="tinyint" precision="1" attributes="unsigned" phptype="integer" null="false" default="0" />
	<field key="published" dbtype="tinyint" precision="1" attributes="unsigned" phptype="integer" null="false" default="0" />
	<field key="createdby" dbtype="int" precision="10" phptype="integer" null="false" default="0" />
	<field key="createdon" dbtype="datetime" phptype="datetime" null="false" />
	<field key="editedby" dbtype="int" precision="10" phptype="integer" null="false" default="0" />
	<field key="editedon" dbtype="datetime" phptype="datetime" null="false" />
	<field key="deleted" dbtype="tinyint" precision="1" attributes="unsigned" phptype="integer" null="false" default="0" />
	<field key="deletedon" dbtype="datetime" phptype="datetime" null="false" />
	<field key="deletedby" dbtype="int" precision="10" phptype="integer" null="false" default="0" />
	<field key="publishedon" dbtype="datetime" phptype="datetime" null="false" />
	<field key="publishedby" dbtype="int" precision="10" phptype="integer" null="false" default="0" />
	<index alias="PRIMARY" name="PRIMARY" primary="true" unique="true">
		<column key="id" collation="A" null="false" />
	</index>
	<aggregate alias="Resource" class="modResource" local="resource_id" foreign="id" cardinality="one" owner="foreign" />
	</object>
</model>
и на вкладке xml schema ждем save, сохраняя ее.

— теперь создаем таблицы в БД на вкладке create Tables и создаем классы на вкладке parse Schema.

Таким образом мы получаем таблицу в БД и xpdo классы для работы с этой таблицей.

Структура моей таблицы:
resource_id - документ, к которому "привязан" вопрос
author - имя автора
author_email - его email
question - текст вопроса
answer - текст ответа
notify - галочка, символизирующая что нужно отправить уведомление автору о том, что не его вопрос появился ответ

---- с колонками ниже MIGx работает САМ, т.е. мы в коде ничего с ними не делаем, они сами заполняются
published
createdby
createdon
editedby
editedon
deleted
deletedon
deletedby
publishedon
publishedby

1.2 Создаем MIGx настройку.
Идем в MIGx — вкладка MIGx (вторая вкладка с настройками)

Делаем новую xqa и по ней правой кнопкой — Экспорт/Импорт, вставляем следующий код:
{
  "formtabs":[
    {
      "MIGX_id":1,
      "caption":"\u0412\u043e\u043f\u0440\u043e\u0441-\u043e\u0442\u0432\u0435\u0442",
      "print_before_tabs":"0",
      "fields":[
        {
          "MIGX_id":1,
          "field":"author",
          "caption":"\u0410\u0432\u0442\u043e\u0440",
          "description":"",
          "description_is_code":"0",
          "inputTV":"",
          "inputTVtype":"",
          "validation":"",
          "configs":"",
          "sourceFrom":"config",
          "sources":"[]",
          "inputOptionValues":"",
          "default":""
        },
        {
          "MIGX_id":4,
          "field":"author_email",
          "caption":"E-mail",
          "description":"",
          "description_is_code":"0",
          "inputTV":"",
          "inputTVtype":"",
          "validation":"",
          "configs":"",
          "sourceFrom":"config",
          "sources":"[]",
          "inputOptionValues":"",
          "default":""
        },
        {
          "MIGX_id":2,
          "field":"question",
          "caption":"\u0412\u043e\u043f\u0440\u043e\u0441",
          "description":"",
          "description_is_code":"0",
          "inputTV":"",
          "inputTVtype":"textarea",
          "validation":"",
          "configs":"",
          "sourceFrom":"config",
          "sources":"[]",
          "inputOptionValues":"",
          "default":""
        },
        {
          "MIGX_id":3,
          "field":"answer",
          "caption":"\u041e\u0442\u0432\u0435\u0442",
          "description":"",
          "description_is_code":"0",
          "inputTV":"",
          "inputTVtype":"textarea",
          "validation":"",
          "configs":"",
          "sourceFrom":"config",
          "sources":"[]",
          "inputOptionValues":"",
          "default":""
        },
        {
          "MIGX_id":6,
          "field":"notify",
          "caption":"\u0423\u0432\u0435\u0434\u043e\u043c\u0438\u0442\u044c \u0430\u0432\u0442\u043e\u0440\u0430 \u043e\u0431 \u043e\u0442\u0432\u0435\u0442\u0435?",
          "description":"",
          "description_is_code":"0",
          "inputTV":"",
          "inputTVtype":"listbox",
          "validation":"",
          "configs":"",
          "sourceFrom":"config",
          "sources":"[]",
          "inputOptionValues":"\u041d\u0435\u0442==||\u0414\u0430==1",
          "default":""
        },
        {
          "MIGX_id":5,
          "field":"published",
          "caption":"\u041e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043d",
          "description":"",
          "description_is_code":"0",
          "inputTV":"",
          "inputTVtype":"listbox",
          "validation":"",
          "configs":"",
          "sourceFrom":"config",
          "sources":"[]",
          "inputOptionValues":"\u041d\u0435\u0442==||\u0414\u0430==1",
          "default":""
        }
      ]
    }
  ],
  "contextmenus":"update||publish||unpublish||recall_remove_delete",
  "actionbuttons":"addItem||toggletrash",
  "columnbuttons":"",
  "filters":"[]",
  "extended":{
    "migx_add":"\u0414\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0432\u043e\u043f\u0440\u043e\u0441",
    "formcaption":"",
    "update_win_title":"\u0420\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u043e\u043f\u0440\u043e\u0441",
    "win_id":"xqa",
    "maxRecords":"",
    "addNewItemAt":"top",
    "multiple_formtabs":"",
    "extrahandlers":"",
    "packageName":"xqa",
    "classname":"xQa",
    "task":"",
    "getlistsort":"createdon",
    "getlistsortdir":"DESC",
    "use_custom_prefix":"0",
    "prefix":"",
    "grid":"",
    "gridload_mode":2,
    "check_resid":1,
    "check_resid_TV":"",
    "join_alias":"",
    "has_jointable":"yes",
    "getlistwhere":"",
    "joins":"",
    "cmpmaincaption":"",
    "cmptabcaption":"",
    "cmptabdescription":"",
    "cmptabcontroller":"",
    "winbuttons":"",
    "onsubmitsuccess":"",
    "submitparams":""
  },
  "columns":[
    {
      "MIGX_id":7,
      "header":"ID",
      "dataIndex":"id",
      "width":"",
      "sortable":"false",
      "show_in_grid":"0",
      "renderer":"",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":6,
      "header":"\u0414\u0430\u0442\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f",
      "dataIndex":"createdon",
      "width":"",
      "sortable":"false",
      "show_in_grid":1,
      "renderer":"this.renderDate",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":1,
      "header":"\u0410\u0432\u0442\u043e\u0440",
      "dataIndex":"author",
      "width":"",
      "sortable":"false",
      "show_in_grid":1,
      "renderer":"",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":8,
      "header":"E-mail",
      "dataIndex":"author_email",
      "width":"",
      "sortable":"false",
      "show_in_grid":1,
      "renderer":"",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":2,
      "header":"\u0412\u043e\u043f\u0440\u043e\u0441",
      "dataIndex":"question",
      "width":"",
      "sortable":"false",
      "show_in_grid":1,
      "renderer":"",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":3,
      "header":"\u041e\u0442\u0432\u0435\u0442",
      "dataIndex":"answer",
      "width":"",
      "sortable":"false",
      "show_in_grid":1,
      "renderer":"",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":9,
      "header":"\u0423\u0432\u0435\u0434\u043e\u043c\u0438\u0442\u044c?",
      "dataIndex":"notify",
      "width":"",
      "sortable":"false",
      "show_in_grid":1,
      "renderer":"this.renderCrossTick",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":4,
      "header":"\u041e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043d",
      "dataIndex":"published",
      "width":"",
      "sortable":true,
      "show_in_grid":1,
      "renderer":"this.renderCrossTick",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    },
    {
      "MIGX_id":5,
      "header":"\u0423\u0434\u0430\u043b\u0435\u043d",
      "dataIndex":"deleted",
      "width":"",
      "sortable":"false",
      "show_in_grid":"0",
      "renderer":"",
      "clickaction":"",
      "selectorconfig":"",
      "renderchunktpl":"",
      "renderoptions":"[]"
    }
  ]
}
Сохраняем и ради интереса жмем редактировать, смотрим какие поля и колонки у нас есть.

2. Делаем стандартную форму на Formit, в которой должны быть поля author, author_email, question. Как вы ее реализуете — ваши заботы.

Что важно для нас, у Formit указываем хук xQaAdd:
&hooks=`email,xQaAdd`
Хук email я тоже использую, что бы пришло администратору сайта уведомление «Добавлен новый вопрос...».

Код хука примерно такой, т.е. мы просто создаем новый объект xQa (вопрос):
$resource_id = $modx->resource->get('id');

$modx->addPackage('xqa', MODX_CORE_PATH.'components/xqa/model/');

$qa = $modx->newObject('xQa');
$qa->set('author', strip_tags($hook->getValue('author')));
$qa->set('author_email', strip_tags($hook->getValue('author_email')));
$qa->set('question', strip_tags($hook->getValue('question')));
$qa->set('resource_id', $resource_id);
$qa->set('published', 0);
$qa->set('createdby', 1);
$qa->set('createdon', strtotime("now"));
$qa->save();

return true;
3. Делаем TV поле с типом ввода migxdb, указываем Конфигурацию xqa (мы ее выше создавали), назначаем TV нужному шаблону.

У ресурса должна появится таблица:


4. Уведомление пользователя об ответе:
Создаем плагин notifyVisitors на событие OnDocFormSave:

<?php
if($modx->event->name != 'OnDocFormSave'){
  return false;
}

$template = $resource->get('template');

switch($template){
  case 7:
  case 15:
    // Вопрос-ответ
    $modx->addPackage('xqa', MODX_CORE_PATH.'components/xqa/model/');
    $qas = $modx->getCollection('xQa', array('deleted' => 0, 'notify' => 1, 'resource_id' => $resource->get('id')));
    foreach($qas as $qa){
      $to = $qa->get('author_email');
      if(!empty($to)){
	// ЗДЕСЬ отправляем письмо, объект $qa у нас есть
      }
      $qa->set('notify', 0);
      $qa->save();
    }
    break;
  default:
    return false;
}
Что делает плагин: при сохранении ресурса получаем все xQa, у которых стоит галочка «Оповестить автора об ответе», далее, например, отправляем письмо (я НЕ ПРИВОЖУ этот код, напишите его сами), ставим notify в 0.
Наумов Алексей
17 октября 2014, 15:25
0
Извиняюсь, забыл. Сейчас в общих чертах накидаю код с одного из сайтов.
Наумов Алексей
16 октября 2014, 08:51
0
Я уже не на первом сайте это делаю через MIGx db, пару сниппетов, формы на Formit и хука к ней.

В админке вопросы появляются в виде таблицы MIGx, как TV поле, там их можно удалять, публиковать, редактировать.

Если интересно — напишу попродробнее.
Наумов Алексей
09 октября 2014, 09:18
0
Кстати, есть еще Mapex первой версии www.createit.ru/blog/modx/2012/mapex-1.0/, который позволяет работать только с точкой. Но еще дополнительно хранит текущий зум и тип карты.

Правда что-то давно все это не обновлялось и не проверялось, даже не знаю, работает ли на MODx 2.3…
Наумов Алексей
08 октября 2014, 10:50
0
Ну директория то указана для пользователя. А getProducts это не пользователь… наверное вручную надо прописать путь.