This package allows you to dynamically show your Laravel Livewire 3 components inside Bootstrap modals.
Warning: This package is not backward compatible with Livewire 2.
- Bootstrap 5 must be installed via webpack first
Require the package:
composer require danyderigon/livewire-bootstrap-modal
Add the livewire:modals
component to your app layout view:
<livewire:modals/>
<livewire:scripts/>
<script src="{{ asset('js/app.js') }}"></script>
Require ../../vendor/danyderigon/livewire-bootstrap-modal/resources/js/modals
in your app javascript file:
import('@popperjs/core');
import '../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js';
import '../../vendor/danyderigon/livewire-bootstrap-modal/resources/js/modals.js';
Make a Livewire component you want to show as a modal. The view for this component must use the Bootstrap modal-dialog
container:
<div>
<div class="modal-header">
<h5 class="modal-title">Modal title</h5>
<button type="button" class="btn-close" wire:click="$dispatch('hideModal')" aria-label="Close"></button>
</div>
<div class="modal-body">
<p>Modal body text goes here.</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" wire:click="$dispatch('hideModal')">Close</button>
<button type="button" class="btn btn-primary">Save changes</button>
</div>
</div>
Show a modal by emitting the showModal
event with the component alias:
<button type="button" wire:click="$dispatch('showModal', {alias: 'modals.create-post'})">
{{ __('Create post') }}
</button>
Pass parameters to the component mount
method after the alias:
<button type="button"wire:click="$dispatch('showModal', {alias: 'modals.update-post', params: {id: {{$post->id}} }})">
{{ __('Update Post #' . $post->id) }}
</button>
The component mount
method for the example above would look like this:
namespace App\Http\Livewire\Modals;
use App\Models\Post;
use Livewire\Component;
class UpdatePost extends Component
{
public $post;
public function mount(int $id)
{
$this->post = Post::find($id);
}
public function render()
{
return view('modals.update-post');
}
}
Hide the currently open modal by emitting the hideModal
event:
<button type="button" wire:click="$dispatch('hideModal')">
{{ __('Close') }}
</button>
You can emit events inside your views:
<button type="button" wire:click="$dispatch('hideModal')">
{{ __('Close') }}
</button>
Or inside your components, just like any normal Livewire event:
public function save()
{
$this->validate();
// save the record
$this->dispatch('hideModal');
}
Use your own modals view by publishing the package view:
php artisan vendor:publish --tag=livewire-bootstrap-modal:views
Now edit the view file inside resources/views/vendor/livewire-bootstrap-modal
. The package will use this view to render the component.