Всего 123 768 комментариев

Денис Усманов
26 октября 2024, 14:55
0
И добавлю, что предлагаемый тобою вариант, полуавтоматический, т.е. после срабатывания придётся менять дату на следующий год. Мне нужно было сделать решение, которое как говорится «на века» и «без лишней возни») т.к. у заказчика сайтом управляет в основном HR отдел по вакансиям, и там точно разбираться с такими вещами не будут.
Денис Усманов
26 октября 2024, 14:50
+1
Привет! Да, можно вполне было пойти, через ресурсы, но мне нужно было решение в виде сниппета, который выводил бы по датам чанки с CSS/HTML/JS в разных местах… Поэтому, сниппет оказался на мой взгляд, самым верным решением.
DimoniXo
26 октября 2024, 12:43
+1
Проблема всё чаще появляется, по причине того, что хостинги переходят на MySQL 8. Причина в том, что gallery использует слово «rank» в запросах а бд, а в новой версии MySQL это слово зарезервировано.
Решение:

В файле
core/components/gallery/processors/mgr/item/getlist.class.php

На строке 31 заменить
public $defaultSortField = 'rank';
на
public $defaultSortField = '`rank`';
На строке 66 заменить
$c->groupBy('rank');
на
$c->groupBy('`rank`');
Андрей Чаплыгин
25 октября 2024, 21:39
0
Alexey, большое спасибо! То что нужно!

Немного дополню для интересующихся:

Если добавить в набор передаваемых параметров
'SOLUTIONTYPE' => 'Sole',
и включить в аккаунте PayPal оплату без авторизации (PayPal Account Optional), при редиректе на оплату в PayPal вы увидите ту же форму входа в аккаунт + появится дополнительная кнопка «Оплатить дебетовой\кредетовой катрой», при клике на которую вас всё равно попросят ввести email адрес, уже после чего дадут заполнить данные карты для оплаты.

Чтобы и этого избежать и упростить жизнь пользователю, впишите в тот же набор параметров ещё вот это
'LANDINGPAGE' => 'Billing',
С этим параметром, пользователь сразу будет отправлен на страницу, где останется только заполнить данные карты, без необходимости нажимать дополнительные кнопки и вводить email.

PS. На всякий случай скажу, что делаю это для клиента из США, поэтому добавил ещё и эту опцию
'LOCALECODE' => 'US',
Не уверен, что она необходима, учитывая что код US вроде как ставится по дефолту, но тем не менее, может кому будет полезно.

Prihod
25 октября 2024, 18:53
0
На прямую нет. msProductRemains хранит остатки в привязке к отдельным опциям товара поэтому нужно через свой плагин согласно своей логике инициировать событие появление товара.

$msinshopnotify = $modx->getService('msinshopnotify', 'MsInShopNotify');
$tools = $msinshopnotify->getTools();
$tools->setInShop($productId);
Николай Артамонов
25 октября 2024, 17:35
0
Спасибо большое! Это был не кэш. Пока ждал ответа меня озарило. Оказалось, что плагин, который обновляет наличие еще реагирует на onDocFormSafe. То есть все, что правишь руками, при сохранении снова перезаписывается. Отсюда и значения ручные слетают.
Alexey
25 октября 2024, 16:09
+1
Привет! Тут посмотри: stackoverflow.com/questions/7689640/paypal-express-checkout-pay-without-account

В класс оплаты на сайте в методе send в массив $params нужно добавить параметр 'SOLUTIONTYPE' => 'Sole', — disk.yandex.ru/i/f59-EKcIiGXNOQ

Плюс в настройках пейпала разрешить оплату без авторизации.

Должно помочь.
Наумов Алексей
25 октября 2024, 14:25
0
Поиском в БД, например через phpMyAdmin. Либо в файлах, если они используются на сайте, обычно это каталог /core/elements
Riwka
25 октября 2024, 13:31
0
Такое может случаться из-за кеша внутренних страниц, например. Ctrl+f5 не помогает увидеть новое значение?
Дима Касаткин
24 октября 2024, 20:59
+2
Ух ты! Осенний код подъехал, спасибо! Всегда жара с заявками в праздники, может и пригодится!

Тоже решаю такие квесты регулярно, поэтому позволю себе задать вопрос)

Просто интересно, а ты не пробовал стандартные для Revo планируемые даты публикации прикрутить для этих целей как-то?

Имею в виду перед тем, как решение выработал. Сниппет конечно круче, т.к. он универсальный, один раз поставил, и будет срабатывать каждый год))

Тоже горожу сниппеты, но сейчас подумал, что по-простому кажется можно было типа такого
[[#8.published:is=`1`:then=`[[#8.content]]`]]
выводить в шаблоне страницы, а в стандартных полях ресурса (с id=8 из моего примера) ставить планируемую дату публикации, и снятия с публикации, вот эти:


Как думаешь, @Денис Усманов, рабочая это схема для одноразовых событий?
Дима Касаткин
24 октября 2024, 20:46
0
Привет! Спасибо за решение, сорри не могу плюсануть уже, время прошло, вовремя не заметил!

Я же правильно понимаю, что можно не делать одноразовый сниппет, а просто запустить его код через компонент Console или подобный?

И ещё есть вопрос по SEOSuite, пользуясь случаем. Они там решили вопрос с тем, что компонент создаёт большую секцию своих настроек в админке для каждого ресурса? Там эта секция была выше, чем секция с основным контентом (и соответственно с секцией TV-шек, если их системной настройкой `tvs_below_content` перенести тоже на первую вкладку в админке где страницы редактируешь) и из-за этого осложнялось редактирование контента на мой взгляд (SEO-настройки маячили и лишний раз мешались). Помню из-за этого даже кто-то ставил старые версии, SEOtab вроде… и ждали фикса, сообщив разрабам на github. Это пофикшено в свежих SEOsuite?
Станислав
24 октября 2024, 15:53
0
Добрый день. Тоже столкнулся с этой проблемой и решил ее так. С сайта ckeditor, в разделе плагины (addon) скачал плагин «justify»: ckeditor.com/cke4/addon/justify. Далее распаковал и и скопировал в /manager/assets/components/ckeditor/ckeditor/plugins (чтобы получилась там папка justify). Далее: Системные настройки, раздел ckeditor.extra_plugins, надо добавить justify. И все появится.
Андрей Чаплыгин
24 октября 2024, 13:47
0
Допускаю что недостаточно хорошо разобрался с этим вопросом, поэтому сформулирую по проще.

Задача: по прежнему принимать оплату на свой аккаунт paypal, только чтобы у клиентов была возможность оплатить картой без необходимости входа в ЛК paypal.

На сколько понимаю эту возможность их система предоставляет, но могу ошибаться с методом интеграции, толи через Integrate PayPal Checkout, толи через API PayPal REST что больше похоже на правду. А может и через тот же NVP/SOAP это можно сделать например поменяв apiUrl…

В общем, буду рад любому вашему опыту.
Сергей Карпович
23 октября 2024, 22:11
0
Работает ли компонент с msProductRemains?
Сергей Карпович
22 октября 2024, 22:56
0
Пробовал сортировку
'sortby' => '{"CAST(\'param_43\' AS DECIMAL (10,2))":"DESC"}'
Но так она полностью игнорируется и выводится по ID
Сергей
22 октября 2024, 10:53
0
Если вы обратите внимание на карточку товара в каталоге, то в ней есть цвета и при фильтрации, грузится эта же карточка товара, только уже с другим заголовком и цветом. Как я понял, это можно сделать с помощью MsOptionsPrice2 и MSearch2. Ну пока у меня какие то проблемы, пытаюсь решить их) А ваш компонент я так понимаю не работает с фильтрацией по опциям и seo фильтр так и не интегрировали. Спасибо за ответ.

Хотя скорее всего там не так реализовано. Там все товары отдельно сделаны, но в фильтре объединены. Я сделал такой плагин (объединяет и выводит товары по полю), но не знаю как его связать с фильтром.
Игорь
21 октября 2024, 22:17
0
А можно для разных пользователей предоставить каждому пользователю свой id страницы для редактирования только своей страницы?
Roman
20 октября 2024, 20:40
0
Из примера

$match = $matched;
        $matched = array();
        $count = count($requested);
        $count_values = array_count_values($match);

        foreach ($count_values as $id => $value) {
            if ($value >= $count) {
                $matched[] = $id;
            } else {
                $matched[] = 0;
            }
        }


$count = count($requested);
Получает количество значений в запросе
$count_values = array_count_values($match);
Получает количество значений в множественном поле ресурса

Можно это применить, чтобы исключить все ресурсы у которых больше одного значения в поле, в моем случае, нужно чтобы исключались те, у которых любое значение совпадает с запросом.