yassir3wad / nova-realtime-notification

This package adds real-time notification broadcasting capabilities to Laravel Nova Notifications, seamlessly integrating with Laravel Nova.
MIT License
2 stars 0 forks source link

Laravel Nova Real-time Notification Broadcasting

This package adds real-time notification broadcasting capabilities to Laravel Nova Notifications, seamlessly integrating with Laravel Nova.

Features

Installation

Requirements

Steps

  1. Install the package via Composer:

    composer require yassir3wad/nova-realtime-notification
  2. Publish the package configuration:

    php artisan vendor:publish --provider="Yassir3wad\NovaRealtimeNotification\ToolServiceProvider"
  3. 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:

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

  1. Create a new notification:

    php artisan make:notification AdminNotification
  2. Implement the via, toNova, and toBroadcast methods in your notification class where you have NovaChannel, and add broadcast to the via 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,
            ]);
        }
    }
  3. 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.

Screenshots

Nova Real-time Notification Nova Real-time Notification