elegantly / livewire-modal
Modal for your Livewire App. Done right.
                                    Fund package maintenance!
                                                                            
                                                                                                                                        ElegantEngineeringTech
                                                                                    
                                                                
Installs: 1 483
Dependents: 2
Suggesters: 0
Security: 0
Stars: 45
Watchers: 1
Forks: 1
Open Issues: 2
Language:Blade
pkg:composer/elegantly/livewire-modal
Requires
- php: ^8.1
- illuminate/contracts: ^10.0||^11.0||^12.0
- livewire/livewire: ^3.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^10.0.0||^9.0.0||^8.22.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3||^2.0
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
README
This package allows you to seamlessly open Livewire components inside modals or slideovers with powerful features:
- Support for modals, slideovers, and similar UI patterns.
- Nested and stacked modals.
- Custom styling and animations, with optional presets.
- Preloading components for faster interactions.
Requirements
- livewire/livewire: v3
- tailwindcss: v3 (not yet tested with v4)
How It Works
This package provides a single Livewire Modal component that should be placed at the end of your body tag. This component dynamically renders and manages all modal instances while maintaining a modal history.
Modals can be opened and closed by dispatching modal-open and modal-close events.
Any Livewire component can be used as a modal without requiring special interfaces or base components—just use your existing components as they are.
Installation
Install the package via Composer:
composer require elegantly/livewire-modal
To customize modal behavior, publish the views with:
php artisan vendor:publish --tag="livewire-modal-views"
Usage
Configuring Tailwind CSS
Since the modal component is styled using Tailwind CSS, you must include its views in your Tailwind configuration file:
export default { content: [ "./vendor/elegantly/livewire-modal/resources/views/**/*.blade.php", ], };
Setting Up Your Application
Add the modal manager component <livewire:modal /> at the end of your body tag, typically in your layout views:
<body> ... <livewire:modal /> </body>
Preparing Your Modals
Any Livewire component can be displayed as a modal. However, certain features, such as stacking, require additional customization.
Creating a Simple Modal Component
This package provides two Blade components to simplify stacking and positioning:
- x-livewire-modal::stack: Provides a basic layout with stacking capabilities.
- x-livewire-modal::modal: Handles positioning and stacking.
Wrap your content within these components:
<x-livewire-modal::stack> <x-livewire-modal::modal position="center" class="w-full max-w-md overflow-auto rounded-lg bg-white p-5" > <div class="prose"> <p> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Etiam rhoncus, augue eget vulputate vehicula, justo dui auctor est, at iaculis urna orci ut nunc. </p> </div> </x-livewire-modal::modal> </x-livewire-modal::stack>
Controlling the Modal Position
By default, modals are centered, but their position can be adjusted using the position prop:
<x-livewire-modal::stack> <x-livewire-modal::modal position="left"> ... </x-livewire-modal::modal> </x-livewire-modal::stack>
<x-livewire-modal::stack> <x-livewire-modal::modal position="bottom"> ... </x-livewire-modal::modal> </x-livewire-modal::stack>
Fullscreen Modal
To make a modal fullscreen, use the fullscreen prop:
<x-livewire-modal::stack fullscreen> ... </x-livewire-modal::stack>
Creating a Slideover Component
<x-livewire-modal::stack> <x-livewire-modal::slideover class="w-full max-w-md overflow-auto rounded-lg bg-white p-5" > <div class="prose"> <p> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Etiam rhoncus, augue eget vulputate vehicula, justo dui auctor est, at iaculis urna orci ut nunc. </p> </div> </x-livewire-modal::slideover> </x-livewire-modal::stack>
Opening a Modal
To open a modal, dispatch a modal-open event:
<button x-modal:open="{ component: 'users.show', props: { userId: 1 } }"> Open </button>
<button x-on:click="$dispatch('modal-open', { component: 'users.show', props: { userId: 1 } })" > Open </button>
Livewire.dispatch("modal-open", { component: "users.show", props: { userId: 1 }, });
Preloading a Modal
To preload a modal, dispatch a modal-preload event with the same props used to open it:
Livewire.dispatch("modal-preload", { component: "users.show", props: { userId: 1 }, });
Preloading a Modal on Hover
Using the custom Alpine directive, you can preload a modal when the user starts hovering over a button. This improves UX by ensuring faster modal openings.
<button x-modal:open.preload="{ component: 'users.show', props: { userId: 1 } }" > Preload and Open </button>
Closing the Current Modal
To close the currently active modal, dispatch a modal-close event:
<button x-modal:close>Close</button>
<button x-on:click="$dispatch('modal-close')">Close</button>
Livewire.dispatch("modal-close");
Closing All Modals
To close all modals at once:
<button x-modal:close-all>Close</button>
<button x-on:click="$dispatch('modal-close-all')">Close All</button>
Livewire.dispatch("modal-close-all");
Testing
Run the test suite with:
composer test
Changelog
For recent changes, see CHANGELOG.
Contributing
See CONTRIBUTING for contribution guidelines.
Security Vulnerabilities
For information on reporting security vulnerabilities, please review our security policy.
Credits
License
This package is licensed under the MIT License. See License File for details.