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

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

С нами с 31 марта 2013; Место в рейтинге пользователей: #13
Наумов Алексей
11 февраля 2015, 20:12
0
Все верно вам написали. Еще посмотрите что бы яндекс карты много раз не подключались, за это отвечает параметр includeJs www.createit.ru/blog/modx/2012/mapex-2-0-yandex-maps-for-modx-revolution/
Наумов Алексей
09 февраля 2015, 08:44
0
Ага, все верно, это я не весь код написал, кусочек вырвал от своего
Наумов Алексей
06 февраля 2015, 09:25
0
Ну там все просто как бы…

if ($modx->event->name == 'OnDocFormSave') {
if($class_key == 'msProduct'){
  if ($resource->get('template') == XXX) {
    $resource->set('tyre_season', $resource->getTVValue('tv_tyre_season'));
    $resource->set('tyre_car', $resource->getTVValue('tv_tyre_car'));
    $resource->set('tyre_width', $resource->getTVValue('tv_tyre_width'));
    $resource->set('tyre_height', $resource->getTVValue('tv_tyre_height'));
    $resource->set('tyre_dia', $resource->getTVValue('tv_tyre_dia'));
    $resource->set('tyre_load', $resource->getTVValue('tv_tyre_load'));
    $resource->set('tyre_speed', $resource->getTVValue('tv_tyre_speed'));
    $resource->set('tyre_strong', $resource->getTVValue('tv_tyre_strong'));
    $resource->set('tyre_studded', $resource->getTVValue('tv_tyre_studded'));
    $resource->set('tyre_runonflat', $resource->getTVValue('tv_tyre_runonflat'));
    $resource->save();
  }
... обрабатываем другие шаблоны
}
}
Наумов Алексей
05 февраля 2015, 10:53
0
Гугли по фразе «changetemplate modx»
Наумов Алексей
04 февраля 2015, 21:01
+1
Неа.

Когда мне нужно было так сделать я создал ВСЕ нужные свойства, затем такие же TV, которые назначил шаблонам, как мне нужно, и в плагине при сохранении товара копировал значения из TV в свойства. Весь этот трюк для правильной и быстрой сортировки и фильтрации, ибо делать JOIN множества TV — накладно
Наумов Алексей
04 февраля 2015, 14:18
+6
Тоже готов скинуться. Но ввиду значительного объема работ и их сроков действительно считаю более разумным сделать поэтапную разработку. Периодическое появление результата будет стимулировать интерес к затее и не позволит ей «затухнуть» в наших умах.
Наумов Алексей
28 января 2015, 16:44
0
Если своими словами:
1. делаем xml схему
2. На ее основе через migx: а) создаем компонент, б) парсим классы, в) создаем таблицы
3. Так же через migx настраиваем интерфейс, настроек там много, но все делается визуально, он сохраняется как конфигурация
4. создаем TV с типом migxdb, указываем ему id конфигурации с прошлого шага, назначаем шаблону, и создаем ресурс с этим шаблоном

в примере по ссылке выше есть поле resource_id, по нему идет автоматическая привязка записей к текущему ресурсу, я всегда это использовал…

по идее после всего этого при редактировании ресурса будет доступна табличка с вашими записями, которые можно добавлять, удалять, изменять
Наумов Алексей
28 января 2015, 16:33
1
0
Весьма просто (если опыта нет) это можно сделать с использованием MIGx db.
И весь интерфейс в админке будет доступен (ну кроме функций экспорта, это придется дописать).

Почитай эту статью rtfm.modx.com/extras/revo/migxdb/migxdb.tutorials/migxdb.create-a-basic-gallery-management-from-scratch-with-migxdb и статьи рядом в этом разделе.
Наумов Алексей
28 января 2015, 16:23
+1
Серия и номер это ресурсы обязательно?

Лучше сделать отдельную таблицу под них, а запросы хранить в еще 1 таблице, структуру ее сделать типа:
дата, запрос, найден(да/нет), id найденого номера
Наумов Алексей
27 января 2015, 10:16
0
почему бы не сделать это в сниппете? Зачем городить такую штуку?

MySnippet:
$param = empty($_GET['param']) ? '' : $_GET['param'];
...
Наумов Алексей
21 января 2015, 16:33
+1
Мне кажется, что речь шла об «умеренном использовании» TV. Я лично пользуюсь, но в меру стараюсь. Что бы избежать излишнего их количества или сортировки по ним.

К примеру если нужно вывести список в 1000 строк и 20 столбцов, где каждый столбец — TV, будут проблемы, так как у нас 20 джойнов получится.

А если же эти 20 TV выводятся просто на одной странице для одного объекта — разницы в скорости вы не увидите.

В общем с умом подходим к делу.
Наумов Алексей
20 января 2015, 22:00
0
Спасибо! Как то странно )
Наумов Алексей
20 января 2015, 08:46
0
Окей, в принципе да. Я об этом тоже подумал.

Но в существующем коде возможности голосовать за объект с другим class нет, я верно понимаю:
github.com/bezumkin/Tickets/blob/master/core/components/tickets/processors/web/ticket/vote.class.php#L53
?

Тогда пишу свой код для поддержки голосования за другие типы объектов на сайте!
Наумов Алексей
18 января 2015, 13:36
0
Для слайдера сделай галерею с использованием MIGx. В случае с 3 изображениями загрузить их вручную вполне себе обыденная задача.
Наумов Алексей
17 января 2015, 17:45
0
Ну вот в форме:
<input type="hidden" name="resource_id" value="[[*id]]" />
resource_id — вы ставите id ТЕКУЩЕГО документа, на котором форма расположена

а в сниппете код:

$doc = $modx->getObject('modResource',array('id'=>$hook->getValue('resource_id')));
 
if (empty($doc)){
    $doc = $modx->newObject('modResource');
    $doc->set('createdby', $modx->user->get('id'));
}
else{
    $doc->set('editedby', $modx->user->get('id'));
}
построчно:
найти ресурс, который указан в поле resource_id
если он пустой — то создать новый ресурс
иначе — редактировать существующий.

отсюда и все идет…

кстати, если кто-то умный подменит и установит resource_id = 1, то будет преспокойно менять текст главной страницы вашего сайта =)

а вообще задача для новичка в MODx — сложная
Наумов Алексей
16 января 2015, 10:34
+1
В принципе я тоже согласен с добавлением пары полей.

Придумать можно много чего.
Например смело:
alt, title,tags (или для упрощения я бы назвал это group). Теги предполагают что их может быть несколько через запятую, все это несколько усложняет реализацию, а группа она группа =), одна, без деления запятыми.

Ну и вообще было бы прикольно добавить field1, field2, field3 просто на всякий случай).

И еще замечание, при генерации названия картинки из имени файла стоит сразу удалять расширение файла, а то руками приходится делать это.
Наумов Алексей
15 января 2015, 08:58
0
Сразу в голову пришло запихнуть куда-нибудь массив вида $sales[$resource_id] = $sale в виде json и проверять новое значение TV с ним.

Или для этих же целей можно использовать:

$prop = $modx->fromJSON($resource->get('properties'));
$old_sale = empty($prop['old_sale']) ? 0 : $prop['old_sale'];

... тут сравниваем скидку с $old_sale
...

$prop['old_sale'] = $resource->getTVValue('sale');

$resource->set('properties', $modx->toJSON($prop')))
$resource->save();


как то так…