Tech Verse Logo
Enable dark mode
Creating Responsive Component Networks with Laravel Livewire's #[On] Event System

Creating Responsive Component Networks with Laravel Livewire's #[On] Event System

Tech Verse Daily

Tech Verse Daily

4 min read

Building interconnected components that communicate seamlessly is essential for modern web applications. Laravel Livewire provides a sophisticated event-driven architecture through its #[On] attribute and dispatch system, enabling components to interact without tight coupling.

The #[On] attribute replaces the traditional $listeners property, offering a cleaner approach to event handling. Components can listen for specific events and react accordingly, creating dynamic interfaces that respond to changes throughout your application.

use Livewire\Component;
use Livewire\Attributes\On;
 
class NotificationBell extends Component
{
    public $unreadCount = 0;
 
    #[On('notification-added')]
    public function incrementCount()
    {
        $this->unreadCount++;
    }
 
    public function render()
    {
        return view('livewire.notification-bell');
    }
}

Events are triggered using the dispatch method from any component within your application. This creates a publish-subscribe pattern where components remain independent while still coordinating their behavior.

class MessageSender extends Component
{
    public function sendAlert($message)
    {
        Notification::create(['message' => $message, 'user_id' => auth()->id()]);
 
        $this->dispatch('notification-added', message: $message);
    }
 
    public function render()
    {
        return view('livewire.message-sender');
    }
}

The system supports multiple event listeners per component and allows for dynamic event names based on component properties. You can also target specific components using the dispatch()->to() method for more precise communication.

#[On('user-{userId}-updated')]
public function refreshUserData($userData)
{
    $this->userData = $userData;
}

Consider implementing a project management dashboard where different components need to stay synchronized. The task board, progress tracker, and team notifications all require updates when project milestones change, but they operate independently of each other.

class ProjectDashboard extends Component
{
    public $activeProjects = [];
    public $completedTasks = 0;
    public $teamAlerts = [];
 
    #[On('task-completed')]
    public function updateProgress($taskData)
    {
        $this->completedTasks++;
        $this->teamAlerts[] = "Task '{$taskData['title']}' completed by {$taskData['assignee']}";
    }
 
    #[On('project-milestone-reached')]
    public function addMilestoneAlert($projectId, $milestone)
    {
        $project = Project::find($projectId);
        $this->teamAlerts[] = "🎉 {$project->name} reached: {$milestone}";
 
        $this->dispatch('send-team-email',
            subject: "Milestone Achievement",
            project: $project->name,
            milestone: $milestone
        );
    }
 
    #[On('new-project-added')]
    public function refreshProjectList()
    {
        $this->activeProjects = Project::where('status', 'active')->get();
    }
 
    public function render()
    {
        return view('livewire.project-dashboard');
    }
}

This dashboard component demonstrates how multiple event types can be handled within a single component. When tasks are completed, milestones are reached, or new projects are added, the dashboard automatically updates its display and can trigger additional actions like sending team notifications.

The event system integrates seamlessly with Laravel Echo for real-time broadcasting, JavaScript event listeners, and Alpine.js components. Events can be dispatched from the server-side PHP code, client-side JavaScript, or directly from Blade templates using the $dispatch helper.

    Latest Posts

    View All

    Handling Large Datasets with Pagination and Cursors in Laravel MongoDB: Offset vs Cursor Pagination

    Handling Large Datasets with Pagination and Cursors in Laravel MongoDB: Offset vs Cursor Pagination

    A Complete Guide: Detecting and Fixing Race Conditions in Laravel Applications

    A Complete Guide: Detecting and Fixing Race Conditions in Laravel Applications

    PestPHP Intellisense in Laravel VS Code Extension v1.7.0

    PestPHP Intellisense in Laravel VS Code Extension v1.7.0

    Laravel Starter Kits Now Come with Built-in Toast Notifications

    Laravel Starter Kits Now Come with Built-in Toast Notifications

    Implement Laravel Search in a Right Way

    Implement Laravel Search in a Right Way

    Installing FreeSWITCH 1.10.X on Ubuntu 18.04 | 20.04 | 22.04 LTS

    Installing FreeSWITCH 1.10.X on Ubuntu 18.04 | 20.04 | 22.04 LTS

    Introducing the Laravel AI SDK — Build Smarter Apps with AI

    Introducing the Laravel AI SDK — Build Smarter Apps with AI

    Laravel AI SDK: Building AI-Powered Applications the Laravel Way

    Laravel AI SDK: Building AI-Powered Applications the Laravel Way

    Getting Started with Mago – The Fastest PHP Tooling Chain

    Getting Started with Mago – The Fastest PHP Tooling Chain

    Best Stack Recommendations for Laravel Projects (Battle-Tested in Production)

    Best Stack Recommendations for Laravel Projects (Battle-Tested in Production)