Dynamic Laravel Livewire Bootstrap modals.

4.0.0 2022-12-17 20:23 UTC

This package is not auto-updated.

Last update: 2024-06-17 01:53:07 UTC


Laravel Livewire Modals

This package allows you to dynamically show your Laravel Livewire components inside Bootstrap modals.



  • Bootstrap 5 must be installed via webpack first


Require the package:

composer require bastinald/laravel-livewire-modals

Add the livewire:modals component to your app layout view:

<script src="{{ asset('js/app.js') }}"></script>

Require ../../vendor/bastinald/laravel-livewire-modals/resources/js/modals in your app javascript file:



Modal Views

Make a Livewire component you want to show as a modal. The view for this component must use the Bootstrap modal-dialog container:

<div class="modal-dialog">
    <div class="modal-content">
        <div class="modal-header">
            <h5 class="modal-title">Modal title</h5>
            <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
        <div class="modal-body">
            <p>Modal body text goes here.</p>
        <div class="modal-footer">
            <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button>
            <button type="button" class="btn btn-primary">Save changes</button>

Showing Modals

Show a modal by emitting the showModal event with the component alias:

<button type="button" wire:click="$emit('showModal', 'auth.profile-update')">
    {{ __('Update Profile') }}

Mount Parameters

Pass parameters to the component mount method after the alias:

<button type="button" wire:click="$emit('showModal', 'users.update', '{{ $user->id }}')">
    {{ __('Update User #' . $user->id) }}

The component mount method for the example above would look like this:

namespace App\Http\Livewire\Users;

use App\Models\User;
use Livewire\Component;

class Update extends Component
    public $user;
    public function mount(User $user)
        $this->user = $user;
    public function render()
        return view('users.update');

Hiding Modals

Hide the currently open modal by emitting the hideModal event:

<button type="button" wire:click="$emit('hideModal')">
    {{ __('Close') }}

Or by using the Bootstrap data-bs-dismiss attribute:

<button type="button" data-bs-dismiss="modal">
    {{ __('Close') }}

Emitting Events

You can emit events inside your views:

<button type="button" wire:click="$emit('hideModal')">
    {{ __('Close') }}

Or inside your components, just like any normal Livewire event:

public function save()

    // save the record


Publishing Assets

Custom View

Use your own modals view by publishing the package view:

php artisan vendor:publish --tag=laravel-livewire-modals:views

Now edit the view file inside resources/views/vendor/laravel-livewire-modals. The package will use this view to render the component.