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

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

С нами с 31 марта 2013; Место в рейтинге пользователей: #13
Наумов Алексей
17 июня 2020, 15:18
0
Я бы предложил ловить 404 ошибку плагином, проверять на нужные условия (url) и отдавать контент на свое усмотрение через sendForward
Наумов Алексей
16 июня 2020, 13:13
0
В смысле как быть? Пусть заполняет через административный интерфейс.
Наумов Алексей
16 июня 2020, 11:29
0
Обычно меню статичные и крайне редко меняются…
Просто укажите в параметре resources нужные ресурсы, а сортировку уберите. В этом случае 2 TV поля будут не нужны.
Наумов Алексей
16 июня 2020, 11:24
+1
Я бы в реализации данной задачи ушел от TV, а сделал отдельный компонент:
— табличка для хранения этапов/задач
— табличка для хранения выполнения этих задач пользователями.

Реализация с кучей TV/ MIGX/ хранением в extended пользователя выглядит навороченной, сложной и проблемной в развитии и эксплуатации.
Наумов Алексей
09 июня 2020, 15:11
+1
Да, это нормально.
В случае ошибки в синтаксисе с Fenom вы получите белый экран.
Наумов Алексей
08 июня 2020, 14:03
0
Если выключен smtp — включить попробовать, или наоборот.
Другой smtp сервер попробовать.
Наумов Алексей
08 июня 2020, 13:46
0
Стоит попробовать другие адреса для отправителя и получателя (from, to), поменять настройки smtp.
Возможно хостинг не отправляет, напишите им.
Наумов Алексей
05 июня 2020, 14:31
0
Так должно прописываться, проверьте:
fullname => user_name
email => user_email

Вот кусочек кода из сниппета ecForm:
if ($modx->user->hasSessionContext($modx->context->get('key'))) {
    $profile = $modx->user->getOne('Profile');
    $data['user_name'] = $profile->get('fullname');
    if(empty($data['user_name'])) {
        $data['user_name'] = $modx->user->get('username');
    }
    $data['user_email'] = $profile->get('email');
}
Наумов Алексей
02 июня 2020, 15:21
0
Если сменить шаблонизатор на Fenom, то жизнь станет проще.
С родным парсером решение или «в лоб» или писать сниппет, который будет готовить данные.
Наумов Алексей
29 мая 2020, 09:25
+1
Я делаю так (именно для создания вкладки у ресурса!):
1. Плагин на OnDocFormRender, для новых ресурсов вкладку не показываю:
<?php
/** @var array $scriptProperties */
switch ($modx->event->name) {
    case 'OnDocFormRender':
        /** @var modResource $resource */
        if ($mode == 'new') {
            return;
        }
...
2. Далее подключаю все нужные js файлы, их у компонента много может быть, я для пример 2 показываю, но по факту их 10+:
$url = $easyComm->config['assetsUrl'];
$modx->controller->addJavascript($url . 'js/mgr/easycomm.js');
.... и остальные файлы
 $modx->controller->addLastJavascript($url . 'js/mgr/widgets/page.panel.js');
3. Далее есть сценарий, что установлен AjaxManager, тогда 2 варианта создания вкладки, немного разных:
if ($modx->getCount('modPlugin', array('name' => 'AjaxManager', 'disabled' => false))) {
            $modx->controller->addHtml('
			<script type="text/javascript">
				Ext.onReady(function() {
					window.setTimeout(function() {
						var tabs = Ext.getCmp("modx-resource-tabs");
						if (tabs) {
							tabs.add({
								xtype: "ec-panel-page",
								id: "ec-panel-page",
								title: _("ec"),
								record: {
									id: ' . $resource->get('id') . '
								}
							});
						}
					}, 10);
				});
			</script>');
        }
        else {
            $modx->controller->addHtml('
			<script type="text/javascript">
				Ext.ComponentMgr.onAvailable("modx-resource-tabs", function() {
					this.on("beforerender", function() {
						this.add({
							xtype: "ec-panel-page",
							id: "ec-panel-page",
							title: _("ec"),
							record: {
								id: ' . $resource->get('id') . '
							}
						});
					});
					Ext.apply(this, {
							stateful: true,
							stateId: "modx-resource-tabs-state",
							stateEvents: ["tabchange"],
							getState: function() {return {activeTab:this.items.indexOf(this.getActiveTab())};
						}
					});
				});
			</script>');
        }
4. ec-panel-home это уже панель вашего компонента, описана в page.panel.js, который был подключен на странице в плагине, ну типа:
easyComm.panel.Page = function (config) {
    config = config || {};
    Ext.apply(config, {
        baseCls: 'modx-formpanel',
        layout: 'anchor',

        hideMode: 'offsets',
        items: [ а здесь все содержимое, вкладки, формы и т.д. ]
    });
    easyComm.panel.Page.superclass.constructor.call(this, config);
};
Ext.extend(easyComm.panel.Page, MODx.Panel);
Ext.reg('ec-panel-page', easyComm.panel.Page);
Наумов Алексей
27 мая 2020, 13:43
0
В принципе да.
А далее просто в зависимости от домена выводите нужные контакты к примеру и т.п.
Наумов Алексей
27 мая 2020, 12:18
0
Если сайты одинаковы — конечно да.
Делал, не раз.
Просто настраиваете, чтобы сайт открывался по всем вашим доменам, это даже скорее не к MODX вопрос, а к хостингу.
Наумов Алексей
26 мая 2020, 16:24
+1
Странно… думаю, что miniShop не заточен для такого использования.
А что если: сделать запрос с json_response, получить информацию о заказе, а потом отправить серверу еще один запрос с №заказа, и уже так сказать, со второй попытки, отрендерить чанк.
Наумов Алексей
26 мая 2020, 16:07
+1
Да, вот она и разгадка:
$scriptProperties = array(
    'json_response' => 1, // ТА-ДАМ
    'max_count' => 1,
    'allow_deleted' => 0,
    'allow_unpublished' => 0
);
Наумов Алексей
26 мая 2020, 16:00
0
Я просмотрел код miniShop2, что-то не вижу, чтобы он отправлял в вывод ответ и прекращал работу php… Например success
А каких-нибудь плагинов на ms*** нет активных у сайта, которые могут так делать?
Наумов Алексей
26 мая 2020, 15:45
0
{$_modx->runSnippet('!pdoMenu', [
    'parents' => $_modx->runSnippet('!getparents'),
    'level' => 1,
    'sortby' => $sortby,
    'tplOuter' => 'chunk'
    'tpl' => 'chunk'
    'tplHere' => 'chunk'

])}
Наумов Алексей
26 мая 2020, 13:13
0
{'pdoMenu' | snippet : [
...
'tpl' => 'tplHideSomeChilds'
]}

tplHideSomeChilds:
<li {$classes}>
    <a href="{$link}" {$attributes}>{$menutitle}</a>
    {if $id != 1532}
        {$wrapper}
    {/if}
</li>
Наумов Алексей
26 мая 2020, 12:05
0
Два сценария:
1. Включить в pdoMenu проверку прав (параметр checkPermissions) и настроить их. Работает, но подтормаживает, т.к. много запросов в БД.
2. Лучше просто пересмотреть верстку, и для авторизованных сделать блок (пример из документации):
{if $_modx->user.id > 0}
    Привет, {$_modx->user.fullname}!
{else}
    Вам нужно авторизоваться!
{/if}
Наумов Алексей
25 мая 2020, 13:18
0
Далек от SqLite.
А какое практическое применение? Какая выгода в сценарии MODX + SqLite?