Новости Joomla

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

👩‍💻 Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод triggerEvent(), с помощью которого раньше вызывались события для плагинов. Теперь чтобы в своём коде вызвать событие для плагина и получить от него результаты нужно:- создать объект класса события- передать в него параметры

use Joomla\CMS\Event\AbstractEvent;use Joomla\CMS\Factory;use Joomla\CMS\Plugin\PluginHelper;// Грузим плагины нужных группPluginHelper::importPlugin('system');// Создаём объект события$event = AbstractEvent::create('onAfterInitUniverse', [    'subject' => $this,    'data'    => $data, // какие-то данные    'article' => $article, // ещё материал вдовесок    'product' => $product, // и товаров подвезли]);// Триггерим событиеFactory::getApplication()->getDispatcher()->dispatch(    $event->getName(), // Тут можно строку передать 'onAfterInitUniverse'    $event);// Получаем результаты// В случае с AbstractEvent это может быть не 'result',// а что-то ещё - куда сами отдадите данные.// 2-й аргумент - значение по умолчанию, // если не получены результаты$results = $event->getArgument('result', []);
Плюсы такого подхода - вам не нужно запоминать порядок аргументов и проверять их наличие. Если вы написали свой класс события, то в плагине можно получать аргументы с помощью методов $event->getArticle(), $event->getData(), $event->getProduct() и подобными - реализуете сами под свои нужды. Если такой класс события написали, то создаёте экземпляр своего класса события и укажите его явно в аргументе eventClass
use Joomla\Component\MyComponent\Administrator\Event\MyCoolEvent;$event = MyCoolEvent::create('onAfterInitUniverse', [    'subject'    => $this,    'eventClass' => MyCoolEvent::class, // ваш класс события    'data'       => $data, // какие-то данные    'article'    => $article, // ещё материал вдовесок    'product'    => $product, // и товаров подвезли]);
Ожидаемо, что класс вашего события будет расширять AbsractEvent или другие классы событий Joomla.🙁 Есть неприятный нюанс - нельзя просто так вызывать событие и ничего не передать в аргументы. Аргумент subject обязательный. Но если вы всё-таки не хотите туда ничего передавать - передайте туда пустой stdClass или объект Joomla\registry\Registry.
@joomlafeed#joomla #php #webdev

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

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
я знаю что это нужно делать в css, но не знаю в какой строке менять параметр цвета  !!!???!!!
*

barfly

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
скорее всего где то туто:

\templates\ja_purity\css\tamplate.css
или
\templates\ja_purity\styles\header\цвет твоего шаблона\style.css
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
не purity а pariiti
это два разных шаблона
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
меня видимо не так поняли
в template.css данного шаблона можно поменять цвет шрифта верхнего меню, а в какой строке?
*

barfly

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
я наверно должен сказать : - упс )))
щаз посмотрю, исправлюсь...
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
успокаивает))))))))
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Barfly ссылку на шаблон дать?
*

barfly

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
возможно это:
Цитировать
#active_menu {
color: #FF5721 !important;

находится в css\colors\red.css
соответственно если выбран red шаблон, и аналогично в другом...
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
не получилось
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
может есть другие варианты?
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
попробую переустановить шаблон...вдруг получится
*

barfly

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
аха: вот тут найди нужное меню, по названию в пояснении. (почти в самом низу css файла нпропмсано)
Цитировать
/* split menu
----------------------------------------------------------- */
#ja-splitmenu a {
   color: #E6E6E6;
}

#ja-splitmenu li.active a,
#ja-splitmenu li.active a:hover,
#ja-splitmenu li.active a:active,
#ja-splitmenu li.active a:focus {
   color: #333333;
   background: url(../../images/red/tab-active-right.gif) no-repeat bottom right;
}

#ja-splitmenu li.active a span,
#ja-splitmenu li.active a:hover span,
#ja-splitmenu li.active a:active span,
#ja-splitmenu li.active a:focus span {
    background: url(../../images/red/tab-active-left.gif) no-repeat bottom left;
   color: #333333;
}

#ja-subnav a {
   color: #333333;
   background: url(../../images/red/bullet-list.gif) no-repeat left center;
}

#ja-subnav a:hover,
#ja-subnav a:active,
#ja-subnav a:focus,
#ja-subnav li.active a,
#ja-subnav li.active a:hover,
#ja-subnav li.active a:active,
#ja-subnav li.active a:focus {
   color: #FF5721;
}

/* Son of Suckerfish Dropdowns
-----------------------------------*/
#ja-cssmenu li ul {
   border: 1px solid #CCCCCC;
}

#ja-cssmenu li ul li {
   border-bottom: 1px solid #CCCCCC;
}

#ja-cssmenu li ul a:hover,
#ja-cssmenu li ul a:active,
#ja-cssmenu li ul a:focus {
   color: #FF5721;
}

#ja-cssmenu li a {
   color: #E6E6E6;
}

#ja-cssmenu li li a:hover,
#ja-cssmenu li li a:active,
#ja-cssmenu li li a:focus {
   background: none;
}

#ja-cssmenu li a.active,
#ja-cssmenu li a.active:hover,
#ja-cssmenu li a.active:active,
#ja-cssmenu li a.active:focus {
   background: #666666;
}

#ja-cssmenu li li a.active,
#ja-cssmenu li li a.hover,
#ja-cssmenu li li a.active,
#ja-cssmenu li li a.focus {
   color: #FF5721 !important;
}

#ja-cssmenu ul li:hover,
#ja-cssmenu ul ul li:hover,
#ja-cssmenu ul li.sfhover,
#ja-cssmenu ul li.havesubchildsfhover,
#ja-cssmenu ul li.havesubchild-activesfhover,
#ja-cssmenu ul ul li.sfhover,
#ja-cssmenu ul ul li.havesubchildsfhover,
#ja-cssmenu ul ul li.havesubchild-activesfhover {
   background: #EDEDED !important;
   color: #FF5721;
}

#ja-cssmenu li a.active-first-item,
#ja-cssmenu li a.active-first-item:hover,
#ja-cssmenu li a.active-first-item:active,
#ja-cssmenu li a.active-first-item:focus {
   color: #FFFFFF;
   background: #666666;
}

/* Transmenu
-----------------------------------*/
.transMenu .item.hover {
   background: #999999;
}

.transMenu .background {
   background-color: #666666!important;
}

.transMenu .item#active, .transMenu .item#active:hover {
   background: #FF5721;
}

#ja-transmenu li a { /* common styles for 1st level menu */
   color: #E6E6E6;
}

#ja-transmenu a.havechild-mainlevel-active-trans,
#ja-transmenu a.havechild-mainlevel-active-trans:hover,
#ja-transmenu a.havechild-mainlevel-active-trans:active,
#ja-transmenu a.havechild-mainlevel-active-trans:focus {
   background: #666666;
}
#ja-transmenu a.havechild-mainlevel-active-trans-first,
#ja-transmenu a.havechild-mainlevel-active-trans-first:hover,
#ja-transmenu a.havechild-mainlevel-active-trans-first:active,
#ja-transmenu a.havechild-mainlevel-active-trans-first:focus {
   background: #666666;
}
#ja-transmenu a.havechild-mainlevel-active-trans-last,
#ja-transmenu a.havechild-mainlevel-active-trans-last:hover,
#ja-transmenu a.havechild-mainlevel-active-trans-last:active,
#ja-transmenu a.havechild-mainlevel-active-trans-last:focus {
   background: #666666;
}

#ja-transmenu a.jahover-active {
   background: #666666;
}

#ja-transmenu a.mainlevel-active-trans,
#ja-transmenu a.mainlevel-active-trans:hover,
#ja-transmenu a.mainlevel-active-trans:active,
#ja-transmenu a.mainlevel-active-trans:focus {
   background: #666666;
}

#ja-transmenu a.havechild-mainlevel-active-trans-first,
#ja-transmenu a.havechild-mainlevel-active-trans-first:hover,
#ja-transmenu a.havechild-mainlevel-active-trans-first:active,
#ja-transmenu a.havechild-mainlevel-active-trans-first:focus,
#ja-transmenu a.mainlevel-active-trans-first,
#ja-transmenu a.mainlevel-active-trans-first:hover,
#ja-transmenu a.mainlevel-active-trans-first:active,
#ja-transmenu a.mainlevel-active-trans-first:focus {
   background: #666666;
}

/* Script Dropline Menu
-----------------------------------*/
#jasdl-mainnav a {
   color: #E6E6E6;
}

#jasdl-mainnav li.active a,
#jasdl-mainnav li.active a:hover,
#jasdl-mainnav li.active a:active,
#jasdl-mainnav li.active a:focus {
   color: #333333;
   background: url(../../images/red/tab-active-right.gif) no-repeat bottom right;
}

#jasdl-mainnav li.active a span,
#jasdl-mainnav li.active a:hover span,
#jasdl-mainnav li.active a:active span,
#jasdl-mainnav li.active a:focus span {
    background: url(../../images/red/ttab-active-left.gif) no-repeat bottom left;
   color: #333333;
}

#jasdl-subnav a {
   background: url(../../images/red/bullet-list.gif) no-repeat left center;
}

#jasdl-subnav a:hover,
#jasdl-subnav a:active,
#jasdl-subnav a:focus {
   color: #FF5721;
}

#jasdl-subnav ul li.active a {
   color: #FF5721;
}
*

barfly

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
переустанавливать не поможет.
поищи лучше тут, нужное тебе меню...
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
отлично...а как мне заменить цвет надписей верхнего меню которые неактивны
*

barfly

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
что у вас под неактивным подразумевается?
*

powermax14

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
кнопки на которые я еще не нажал
*

barfly

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
проще будет вам тут http://extensions.joomla.org/extensions/tools/design-tools скачать редактор какой то,
например к дримвайверу и там всё поменять наглядно...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как создать новый блок в шаблоне?

Автор moov

Ответов: 7
Просмотров: 7753
Последний ответ 17.12.2018, 14:08:12
от arma
Ширина меню

Автор alex86r93

Ответов: 5
Просмотров: 4850
Последний ответ 14.06.2018, 05:13:50
от KANEGI
как сделать кнопки меню!

Автор Millenium_3000

Ответов: 10
Просмотров: 11365
Последний ответ 17.08.2017, 17:24:12
от Intrande
Вопрос по добавлению тега в МЕНЮ j 1.5

Автор berTalino

Ответов: 12
Просмотров: 4580
Последний ответ 29.03.2017, 16:20:43
от berTalino
Как увеличить ширину левого меню?

Автор afina2009

Ответов: 8
Просмотров: 2669
Последний ответ 09.04.2016, 23:00:36
от afina2009