Александр Туниеков

Александр Туниеков

С нами с 19 декабря 2015; Место в рейтинге пользователей: #15
Александр Туниеков
04 марта 2020, 13:02
0
Не нужно лезть в исходники!!!
Думал расширить феном, но там все функции оказались privite и protected. И меня это так разочаровало, что функции pdoTools я и не думал расширять, а тупо писал что мне нужно в исходники. Иногда нужно исходники править, чтоб не усложнять код и, если исходники обновились, чтобы компонент смог работать.
Я не мучал автора своими пулами.
Зря :-). Авторы бывают ленивыми и зазнайками. Их надо мучать, чтоб прогресс был. Подзапросы вроде вещь актуальная. Разве нет?
И не стоит плодить кучу разных компонентов. В wordpress, взяв сделанный кем-то сайт, приходиться изучать десяток новых плагинов. Такой компонент как pdoTools лучше, чтоб один был и со стандартным синтаксисом.
Александр Туниеков
03 марта 2020, 22:59
0
Решил проверить как сработает и написал простенький код :-):
{'!pdoResources' | snippet :[
    'loadModels'=>'tSklad',
    'subpdo'=>[
        'test'=>[
            'class'=>'tSkladDetNSLink',
            'alias'=>'NextDNL',
            'select'=>[
                'NextDNL'=>'NextDNL.smena_id',
            ],
            'leftJoin'=>[
                'NextS'=>[
                    'class'=>'tSkladSmena',
                    'on'=>'NextS.id=NextDNL.smena_id',
                    'where'=>[
                        'NextS.date > Smena.date',
                    ],
                ],
            ],
            'where'=>[
                'NextS.date > Smena.date',
            ],
            'sortby'=>[
                'NextS.date'=>'ASC',
                'NextS.number'=>'ASC',
            ],
            'limit'=>1,
        ],
    ],
    'class'=>'tSkladDetNSLink',
    'select'=>[
        'tSkladDetNSLink'=>'tSkladDetNSLink.id,Smena.id as smena_id, ({$subpdo.test}) as on_next_smena_id',
    ],
    'leftJoin'=>[
        'Smena'=>[
            'class'=>'tSkladSmena',
            'on'=>'Smena.id=tSkladDetNSLink.smena_id',
        ],
    ],
    'where'=>[
        'Smena.id > 0',
    ],
    'sortby'=>[
        'tSkladDetNSLink.id'=>'DESC',
    ],
    'limit'=>10,
    'tpl'=>'subpdo_test',
    'showLog'=>1,
]}
И этот код я уже считаю простеньким :-). Есть у меня подобные конфиги и на 571 строку! Жесть.
Вот вывел:
Александр Туниеков
03 марта 2020, 22:04
+1
Поправил. Правильно поправил-то?
Александр Туниеков
03 марта 2020, 21:30
0

Это из-за чего могли отступы полезть?
Александр Туниеков
03 марта 2020, 20:54
0
Напишите с pdoFetch запрос
SELECT tSkladDetNSLink.id, Smena.id, (SELECT NextDNL.smena_id
FROM `modx_tsklad_detail_naryad_smena_link` AS `NextDNL`
LEFT JOIN `modx_tsklad_smena` `NextS` ON NextS.id=NextDNL.smena_id
WHERE NextS.date > Smena.date
ORDER BY NextS.date ASC, NextS.number ASC
LIMIT 1) AS on_next_smena_id
FROM `modx_tsklad_detail_naryad_smena_link` AS `tSkladDetNSLink`
LEFT JOIN `modx_tsklad_smena` `Smena` ON Smena.id=tSkladDetNSLink.smena_id
WHERE Smena.id > 0
ORDER BY tSkladDetNSLink.id DESC
LIMIT 10
так, чтоб в конфиге запроса не было названий таблиц с префиксом базы modx_tsklad_detail_naryad_smena_link, modx_tsklad_smena и не надо лишних сниппетов(Я уже заманался вспоминать какой сниппет для чего нужен). Я проверю у себя :-).
Александр Туниеков
03 марта 2020, 20:38
0
Потом сложно обновлять сайты, и нужно все файлы сверять.
Надеюсь Василий пул реквест примет и будет стандарт. Подзапросы нужны, хотя и не часто.
Александр Туниеков
03 марта 2020, 20:34
0
Подзапросы pdoTools не умеет делать!!! Точнее pdoFetch не умеет.
Александр Туниеков
03 марта 2020, 20:12
0
Можно этот релиз юзать и никаких пробелов ставить не надо :-).
Александр Туниеков
29 февраля 2020, 18:30
0
В качестве финального решения возможно стоит использовать alias. В одном и том же контексте двух элементов с одним alias быть не может, а следовательно его можно использовать как ключ.
Может быть :-). У папки может быть включено использовать псевдоним в uri. То есть уникальный, по идее, только uri, но gitify uri использует и все равно какие-то проблемы. И, если id ресурсов меняются, надо в шаблонах и чанках id ресурса переписывать в конструкциях типа
{123 | url}
{$_modx->makeUrl(21)}
и т.д.
Александр Туниеков
23 февраля 2020, 12:51
0
Как сложно все. И просто компонент синхронизации для MODX не сделаешь.
У меня такая задача. На модкс частично перенесена система управления производством (Первоначально сделанная на Excel директором. Но excel тупит на больших объемах данных и синхронизация разных книг еще тот геморой). Регулярно на сайте что-то меняется. Сейчас, чтобы не мешать рабочему процессу фирмы, сделали тестовую копию сайта. Теперь желательно сделать так чтобы ее можно было быстро синхронизировать с рабочим сайтом.
Нужно чтоб с тестового сайта переносились изменения всех ресурсов, копировались все измененные файлы компонентов и переносилась структура таблиц компонентов без изменения данных. Еще таблицы с настройками желательно настроить чтоб копировались, но это можно и ручками.
Если тут спецы по Gitify есть, подскажите пожалуйста, это можно сделать? И где смотреть как такое организовать?
Александр Туниеков
23 февраля 2020, 12:09
0
ААА… блин. Вот я прокосячил. На меню то слева не посмотрел :-(. Простите плиз.
Александр Туниеков
23 февраля 2020, 11:38
0
Ну блин. Я же справку хочу. Как установить, как синхронизировать гит какой устанавливать. На виндоус запуститься ли? и т.д. А про то что Gitify есть я давно в курсе. Только инфу по разным сайтам собирать и тестить как что работает не охота. И времени особо на это нет.
Александр Туниеков
23 февраля 2020, 07:57
0
Часто возникает ситуация, что тестовая версия сайта начинает плотно отставать по контенту от продакшена и необходимо как-то синхронизировать изменения.
Актуальная тема :-). Как-то давно написал ChangePack, но сейчас даже сам им не пользуюсь :-(. В чем в ChangePack косяки уже забыл. Наверно, что изменения в файлах не ловит и что поменялось в сниппетах и чанках нельзя посмотреть. Но счас тестовый и рабочий сайт надо будет полгода, пока активно разработка идет, синхронизировать. А в ручную это полчаса-час.
Про Gitify есть где-нибудь хорошее описание? На русском, текстовое и актуальное :-)?
Александр Туниеков
08 февраля 2020, 16:31
0
А вот это не знал :-) лови плюс. Блин почему-то не ставиться плюс :-(
Александр Туниеков
04 февраля 2020, 18:34
0
Думаю такого нет. Задача сделать просто тупо экспорт не практичная :-). Просто так же файл с данными никому не нужен. Если делают экспорт, то подразумевается и импорт в 1с или в Яндекс маркет или на другой сайт. Наверно вам стоит определиться куда импорт нужен и от этого уже искать.
Александр Туниеков
10 декабря 2019, 07:58
0
А блин еще надо добавить &elementClass=`modSnippet`. Я же сниппет у себя скопировал в MODX и elementClass в параметрах по умолчанию шел.
Обновил getCacheSensitive
Добавил if(empty($elementClass)) $elementClass = 'modSnippet';
Александр Туниеков
10 декабря 2019, 07:06
0
С mFilter2 вот эти параметры должны быть так:
&element=`mFilter2` &cacheKey=`mFilter2`
В assets/components/msearch2/action.php есть такая строка:
$config = @$_SESSION['mSearch2'][$_REQUEST['key']];
То есть mFilter2 свой конфиг в сессию пишет. Чтоб getCacheSensitive мог mFilter2 кешировать надо будет в него добавить перехват сессии еще.
А в текущей версии не будет работать. Могу его доработать под mFilter2, но платно :-). И мне надо будет доступы к сайту с mFilter2, чтоб тестировать как будет работать.
Александр Туниеков
08 декабря 2019, 20:50
0
Думаю подойдет. Если не используются &toPlaceholders или &toSeparatePlaceholders. В getCache только &toPlaceholder обрабатывается. Можно так же как скрипты перехватывать изменения $modx->placeholders, но пока не требовалось.
Александр Туниеков
20 ноября 2019, 18:41
+1
Словил подарок от Ростелекома.

Ищу в поиске «баннер в браузере r.analytic.host»
и первая же ссылка https://forum.kasperskyclub.ru/index.php?showtopic=62477&p=928487
Я в шоке. Когда владелец сайта ставит рекламу — это понятно. А вот когда провайдер так внезначай свои баннеры пихает это что-то за гранью. Однозначно суд. Пошел искать адвоката :-). По факту нарушение прав пользователя. А де юре может сложно будет доказать :-(.