Just like the other theme components, this one requires some route aliases to work. Please refer to the component overview to learn about the route alias details.
- all_messages
- message
In order to use this component, your user class has to implement the Avanzu\AdminThemeBundle\Model\MessageInterface
<?php
namespace MyAdminBundle\Model;
// ...
use Avanzu\AdminThemeBundle\Model\MessageInterface as ThemeMessage
class MessageModel implements ThemeMessage {
// ...
// implement interface methods
// ...
}
Next, you will need to create an EventListener to work with the MessageListEvent
.
<?php
namespace MyAdminBundle\EventListener;
// ...
use Avanzu\AdminThemeBundle\Event\MessageListEvent;
use MyAdminBundle\Model\MessageModel;
class MyMessageListListener {
// ...
public function onListMessages(MessageListEvent $event) {
foreach($this->getMessages() as $message) {
$event->addMessage($message);
}
}
protected function getMessages() {
// retrieve your message models/entities here
}
}
Finally, you need to attach your new listener to the event system:
<!-- Resources/config/services.xml -->
<parameters>
<!-- ... -->
<parameter key="my_admin_bundle.message_list_listener.class">MyAdminBundle\EventListener\MyMessageListListener</parameter>
<!-- ... -->
</parameters>
<services>
<!-- ... -->
<service id="my_admin_bundle.message_list_listener" class="%my_admin_bundle.message_list_listener.class%">
<tag name="kernel.event_listener" event="theme.messages" method="onListMessages" />
</service>
<!-- ... -->
</services>