yassir3wad / nova-realtime-notification
This package adds real-time notification broadcasting capabilities to Laravel Nova Notifications.
Fund package maintenance!
:vendor_name
Installs: 1 501
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: ^7.3|^8.0
This package is auto-updated.
Last update: 2025-05-12 23:08:38 UTC
README
This package adds real-time notification broadcasting capabilities to Laravel Nova Notifications, seamlessly integrating with Laravel Nova.
Features
- Real-time notifications broadcasting using Laravel Echo.
- Seamless integration with Laravel Nova.
- Configurable broadcast channels and events.
- Option to play sound on receiving notifications.
Installation
Requirements
- Laravel Nova 4.x or higher
Steps
-
Install the package via Composer:
composer require yassir3wad/nova-realtime-notification
-
Publish the package configuration:
php artisan vendor:publish --provider="Yassir3wad\NovaRealtimeNotification\ToolServiceProvider"
-
Configure your broadcasting settings in
config/broadcasting.php
. Ensure you have the necessary drivers (e.g., Pusher, Redis, etc.) configured.
Configuration
The package configuration can be found in config/nova-realtime-notification.php
. You can customize the following settings:
enabled
: Enable/disable real-time notifications.broadcast_driver
: The broadcast driver to be used (e.g.,pusher
,reverb
).broadcast_channel
: The private broadcast channel for notifications. Supported values areApp.Models.User
,App.Models.Provider
, andApp.Models.Customer
.enable_sound
: Enable/disable sound for notifications.sound_path
: The path to the sound file in your public directory.
Example configuration (config/nova-realtime-notification.php
):
return [ 'enabled' => true, 'broadcast_driver' => 'pusher', 'broadcast_channel' => 'App.Models.User', 'enable_sound' => true, 'sound_path' => 'sounds/sound1.mp3', ];
Usage
Broadcasting Notifications
-
Create a new notification:
php artisan make:notification AdminNotification
-
Implement the
via
,toNova
, andtoBroadcast
methods in your notification class where you haveNovaChannel
, and addbroadcast
to thevia
method:namespace App\Notifications; use Illuminate\Bus\Queueable; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Notifications\Messages\BroadcastMessage; use Illuminate\Notifications\Notification; use Laravel\Nova\Notifications\NovaChannel; use Laravel\Nova\Notifications\NovaNotification; class AdminNotification extends Notification implements ShouldQueue { use Queueable; private $message; private $actionPath; private $actionLabel; private $level; public function __construct($message, $actionPath, $actionLabel, $level) { $this->message = $message; $this->actionPath = $actionPath; $this->actionLabel = $actionLabel; $this->level = $level; } public function via($notifiable) { return [NovaChannel::class, 'broadcast']; } public function toNova() { return (new NovaNotification) ->message($this->message) ->action($this->actionLabel, $this->actionPath) ->icon('bell') ->type($this->level); } public function toBroadcast(object $notifiable): BroadcastMessage { return new BroadcastMessage([ 'message' => $this->message, 'action_label' => $this->actionLabel, 'action_path' => $this->actionPath, 'level' => $this->level, 'duration' => 7000, ]); } }
-
Trigger the notification from your application logic:
use App\Notifications\AdminNotification; use App\Models\User; $user = User::find(1); $user->notify(new AdminNotification('You have a new admin message!', '/admin/messages', 'View', 'info'));
Contributing
Thank you for considering contributing to the Laravel Nova Real-time Notification Broadcasting package! Please read the contribution guidelines for details.
License
This package is open-sourced software licensed under the MIT license.