lithemod / events
Lithe Events: A powerful and lightweight event management system for PHP projects, designed to simplify communication between components intuitively and efficiently. Easily create, register, and emit events, making your code more modular and reactive. Transform your applications into dynamic experie
Requires
- lithemod/orbis: ^1.0
Requires (Dev)
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2024-10-20 18:08:19 UTC
README
Lithe Events is a lightweight event handling library designed for PHP applications. It provides a straightforward way to create and manage events, supporting a decoupled architecture that enhances the maintainability and flexibility of your applications.
Table of Contents
Installation
To install lithemod/events
, use Composer. Run the following command in your project directory:
composer require lithemod/events
This command will download the package and update your composer.json
file accordingly.
Usage
Using the EventDispatcher Class
The EventDispatcher
class serves as the core for managing events and listeners. Here's how to use it effectively:
Creating an Event
To create an event, instantiate the Event
class:
use Lithe\Events\Event; $event = new Event('event.name', ['key' => 'value']);
- Parameters:
event.name
: A string that identifies the event.['key' => 'value']
: An optional associative array to store additional event data.
Registering Listeners
You can create an instance of EventDispatcher
and register a listener for an event using the on
method. A listener is a callable executed when the event is emitted.
use Lithe\Events\EventDispatcher; $dispatcher = new EventDispatcher(); $listener = function ($data) { echo "Event data: " . json_encode($data); }; // Register the listener $dispatcher->on('event.name', $listener);
Emitting Events
To emit an event and trigger all registered listeners, use the emit
method:
$event = new Event('event.name', ['key' => 'value']); $dispatcher->emit($event);
Removing Listeners
If you need to remove a listener from an event, use the off
method:
$dispatcher->off('event.name', $listener);
Using Orbis Event Functions
In addition to using the EventDispatcher
, you can utilize helper functions provided by the Orbis
namespace for convenient event management.
Registering Listeners
To register a listener for an event using Orbis, use the on
function:
use Lithe\Orbis\Events; $listener = function ($data) { echo "Event data: " . json_encode($data); }; // Register the listener Events\on('event.name', $listener);
Emitting Events
To emit an event using Orbis, call the emit
function:
use Lithe\Orbis\Events; use Lithe\Events\Event; $event = new Event('event.name', ['key' => 'value']); Events\emit($event);
Removing Listeners
To remove a registered listener with Orbis, use the off
function:
Events\off('event.name', $listener);
Example
Here's a complete example of how to use lithemod/events
with the Orbis
event functions:
use Lithe\Events\Event; use Lithe\Orbis\Events; // Create a listener $listener = function ($data) { echo "Event received with data: " . json_encode($data) . "\n"; }; // Register the listener Events\on('my.event', $listener); // Emit the event $data = ['msg' => 'Hello, world!']; Events\emit(new Event('my.event', $data)); // Remove the listener Events\off('my.event', $listener);
License
This project is licensed under the MIT License.