Новости Joomla

Рендер пользовательского поля внутри другого пользовательского поля. Joomla 5.3

Писал ранее о том, как внутри одного пользовательского поля рендерить другое пользовательское поле. Применил для этого возможность Joomla обращаться к методам плагинов напрямую. Процитирую строчку кода из предыдущего поста:

<?php
$joomlaFieldContentPlugn->onContentPrepare('com_content.article', $fakeItem, $app->getParams());

Joomla постепенно переходит от простого указания аргументов для триггеров плагинов к собственным классам событий. Это позволяет не запоминать порядок передачи аргументов класса и использовать человекопонятные методы $event->getContext(), $event->getItem() и т.д. А то в одном месте в Joomla было $article, в другом - $item, в третьем ещё как-то... Порядку больше становится.

Сегодня обновил сайт клиентов до Joomla 5.3. В ней обновили контент-плагин fields и мой финт ушами с вызовом метода плагина отвалился потому, что я передавал в нём 3 аргумента, вместо одного. И для события onContentPrepare это должен быть объект класса ContentPrepareEvent. Как меняется фрагмент кода из предыдущего поста:

<?php
// мы находимся в файле макета поля

use Joomla\CMS\Event\Content\ContentPrepareEvent;
use Joomla\CMS\Factory;

$app = Factory::getApplication();
$fakeItem = new \stdClass();
// Получаем id текущего материала из объекта Input
$fakeItem->id = $app->getInput()->getInt('id');
// {field 29} - это шорт код вставки поля с id 29 - "ассортимент проекта"
// к содержимому поля конкатенируем шорт-код для обработки
$fakeItem->text = $field->value . '{field 29}';
// Получаем объект плагина
$joomlaFieldContentPlugn = $app->bootPLugin('fields', 'content');
// вызываем метод обработки напрямую
// вместо 3-х аргументов теперь указываем один
// это объект класса ContentPrepareEvent
$joomlaFieldContentPlugn->onContentPrepare(new ContentPrepareEvent('onContentPrepare', [
            'context' => 'com_content.article',
            'subject' => $fakeItem,
            'params'  => $app->getParams(),
            'page'    => 0,
        ]));
// выводим оба поля
echo $fakeItem->text;

@webtolkru 

Вышел релиз Joomla 5.3.0

Вышел релиз Joomla 5.3.0

Проект Joomla с радостью объявляет о выходе Joomla 5.3 — последней минорной версии в серии Joomla 5.

Этот релиз сосредоточен на продуманных улучшениях, которые совершенствуют работу с CMS. От лучшей организации файлов и журналирования задач до расширенной обработки электронной почты и улучшенной доступности — Joomla 5.3 помогает администраторам и разработчикам работать более эффективно, сохраняя ваш сайт современным, безопасным и готовым к будущему.

0 Пользователей и 1 Гость просматривают эту тему.
  • 6 Ответов
  • 4363 Просмотров
*

ArbaT

  • Захожу иногда
  • 63
  • 1 / 1
  • ...легко!
Выгружаю с удаленного магазина в формате CSV, правлю количество, загружаю обратно в магазин, а там всякая лажа начинается...

Как быть, если у меня в день цены на 1000 товаров меняются, что делать?
*

tug

  • Захожу иногда
  • 333
  • 40 / 4
"всякая лажа начинается"
Очень трудно диагностировать причину данного явления =)
*

fdv

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Примерно догадываюсь что имеллось ввиду
ПРи выгрузке  (сам столкнулся сегодня) :
 несколько полей идут нормально, артикул,  цена, скидки - тоесть маленькие цифровые значения, а вот  описания и длинные наименования оказываются не в 1 ячейке, а в разбиты на несколько ячеек  в соседних столбцах.
тоесть
материнская плата  бубубубуб 2223333 - так должно быть
А ТАК ПОЛУЧАЕТСЯ                материнская[ плата[ бубубубуб[ 2223333[
 или артикул и наименование в 1 строке а описание цены в следующей строке таблицы
 в общем что с этим делать незнаю, покрайней мере доступными из админки средствами это не сог выправить, попутно поломал  Джумлу, и пришел к выводу, ну его нафиг эту рыбалку и счас ставлю 1.0.3, жаль конечно, но обновлять под 2000 товара ручками как то.... нет худа без добра   будем получать  дополнительные знанияю

Вот заодно и пожаловался  ;D
*

ArbaT

  • Захожу иногда
  • 63
  • 1 / 1
  • ...легко!
"всякая лажа начинается"
Очень трудно диагностировать причину данного явления =)
tug Я думаю что это проще показать на примере, скажи когда ты будешь в ОН-лайне, я дам дебе доступ к магазину и ты сам увидишь о чем я и сообща попробуем решить эту проблемку, а после можно будет опубликовать способ изменения остатков и цен товаров в больших количествах с пошаговой инструкцией!
*

tug

  • Захожу иногда
  • 333
  • 40 / 4
стучись в асю
*

ArbaT

  • Захожу иногда
  • 63
  • 1 / 1
  • ...легко!
стучись в асю

А в асе кто нить еще бы ответил, было бы вообще хорошо)))
*

fdv

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Провел эксперимент. Занес Н-ное колличество товаров,  выгрузил их из магазина в Csv УДАЛИЛ весь товар, категории, оставил только производителя. налог, ну и картинки нетрогал естественно. Потом загрузил  файлик, все товарысели  отлично,  все как и положено, Хотя  сам файлик в опенофисе выглядит пугающе.  Файлик csv по шаблогу г-на tug тоже заливается нормально. В общем както странно это выглядит и пугающе :)
Попутно прошу пояснить. В выгрузке - загрузке Csv есть пометки, собственный порядок и стандартный, а также вкладка с настройками. Если несложно разъясните в чем отличие этих способов и что задается на в кладке настроек, дополнительные поля которые выгружаются в csv или что?

PS увеличил колличество товаров. поробовал повторить опыт. результат печален :(
часть описания товаров оказалась в названии, продавец в комментариях, в общем началась путаница в  полях  :-\
« Последнее редактирование: 30.04.2006, 15:15:46 от fdv »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Поиск работает только под админом

Автор sete

Ответов: 1
Просмотров: 1285
Последний ответ 23.06.2011, 22:58:28
от sete
не работает на хосте

Автор Бэк

Ответов: 1
Просмотров: 1672
Последний ответ 12.06.2010, 05:00:59
от valagoff
Не работает поиск по параметрам для зарегистрированных пользователей

Автор Marcus

Ответов: 0
Просмотров: 1307
Последний ответ 13.07.2009, 16:19:27
от Marcus