This package provides flash message capability using Laravel Livewire. It is based very literally on laracasts/flash
but has been extended to add the ability to flash a message to a the flash container (a Livewire component) without reloading the page.
This package also retains much (though not all) of the same capability for "normal" flash messages, which are displayed on refresh by the same Livewire component.
Install via composer:
composer require mattlibera/livewire-flash
- Laravel >=7.0
- Livewire ^1.2 or ^2.0
For new applications, consider using the TALL preset for Laravel: [https://github.com/laravel-frontend-presets/tall], or this package also works well with Laravel Jetstream: [https://jetstream.laravel.com/]
Out of the box, the default alert component uses:
- TailwindCSS
- FontAwesome
However, it's fairly trivial to implement your own views / styles instead, by publishing the config and overriding defaults. See below for more on that.
If you are using Tailwind CSS, you'll likely want to amend the content
section of your tailwind.config.js
to include the appropriate files from this package:
/** @type {import('tailwindcss').Config} */
module.exports = {
content: [
"./resources/**/*.blade.php",
"./resources/**/*.js",
"./resources/**/*.vue",
"./vendor/mattlibera/livewire-flash/src/publish/livewire-flash.php",
"./vendor/mattlibera/livewire-flash/src/views/livewire/*.blade.php",
],
theme: {
extend: {},
},
plugins: [],
}
Of course, if you publsh the views/config, you'll reference your own copies instead.
Call the flash()
helper from your code somewhere, before you redirect.
public function store()
{
flash('Success!');
return redirect()->back();
}
From your Livewire component, flash your message using the normal syntax, but then call the livewire()
helper method as the last method in the chain. You must pass in $this
as the argument, as this package utilizes the emit
helper that exists on all Livewire components. Example:
public function livewireAction()
{
flash('Your request was successful!')->success()->livewire($this);
}
Message types are defined in the livewire-flash.php
config file, which can be published (see below) if desired. By default, there are four supported message types: info
(default if nothing else is specified), success
, warning
, and error
.
To set a message's type, either:
- Pass it as the second argument to
flash()
- example:flash('Your action succeeded', 'success')
, or - Chain it as a method name fluently after
flash()
- example:flash('Your action succeeded')->success()
Both of those will change the message's display (colors and icon) to the configured styles.
Overlay message is defined in the livewire-flash.php
config file, which can be published (see below) if desired.
To set an overlay message, chain the method name overlay()
after flash()
. When using overlay leave the flash()
parameter empty. Enter your message as the first parameter and title as second parameter for overlay()
. This can be used with or without the livewire($this)
suffix:
// renders on next page load
flash()->overlay('This is my message', 'The Title');
return redirect('somewhere');
// renders immediately via Livewire
flash()->overlay('This is my message', 'The Title')->livewire($this);
Note that the out-of-the-box overlay component does support HTML code for the body and title, using the Blade unescaped {!! !!}
tags.
To change the styles used by each message type, OR to add your own types, first publish the config file:
php artisan vendor:publish --provider="MattLibera\LivewireFlash\LivewireFlashServiceProvider"
Then, in the styles
key you can change whatever you want:
'styles' => [
'info' => [
'bg-color' => 'bg-blue-100', // could change to bg-purple-100, or something.
'border-color' => 'border-blue-400',
'icon-color' => 'text-blue-400',
'text-color' => 'text-blue-800',
'icon' => 'fas fa-info-circle', // could change to another FontAwesome icon
],
Or you can add your own:
'notice' => [
'bg-color' => 'bg-orange-100',
'border-color' => 'border-orange-400',
'icon-color' => 'text-orange-400',
'text-color' => 'text-orange-800',
'icon' => 'fas fa-flag',
],
Whatever the case, just ensure that you call the alert by its config key: flash('An important message')->notice()
To customize overlay styles, see the overlay
key of the config file.
Out of the box, the Livewire Flash Container component is registered for you. All you have to do is include it in your template:
<livewire:flash-container />
There are also some sample alert components (styled using TailwindCSS) included with this package. However, if you do not wish to use those...
You can change the views that the Livewire components use for rendering, and the styles applied to each message type.
If you are not using TailwindCSS and/or FontAwesome, you should definitely do this to call your own alert component/partial to fit whatever your stack is using.
First, publish the config file:
php artisan vendor:publish --provider="MattLibera\LivewireFlash\LivewireFlashServiceProvider"
Then, edit the views
area:
'views' => [
'container' => 'livewire-flash::livewire.flash-container',
'message' => 'partials.my-bootstrap-flash',
],
You can access the public message properties on MattLibera\LivewireFlash\Message
, as well as $styles
(which is injected via the Livewire component) in your template.
By default, each message will be set to be dismissable (that is, have an X icon at the right that will close the alert). If you wish to prevent this, you can chain ->notDismissable()
(or ->dismissable(false)
) to your flash directive.
You can add your own magic via AlpineJS or whatever else if you want to fade messages out automatically - right now each message is a Livewire component and uses Livewire logic to hide it when it is dismissed.
Note that the overlay does not support this directive.
Multiple flash messages can be sent to the session:
// anywhere
flash('Message 1');
flash('Message 2')->warning();
return redirect('somewhere');
OR
// livewire component
flash('Message 1')->livewire($this);
flash('Message 2')->warning()->livewire($this);
However, at the moment, because of the way Livewire handles the session, you cannot mix-and-match... that is, you cannot do:
// livewire component
flash('Message 1'); // this one will get lost.
flash('Message 2')->livewire($this); // this one will show on current page via Livewire
I am open to contributions to this package, and will do the best I can to maintain it over time. Pull requests are welcome, and in fact encouraged. Right now there are no specific guidelines for a PR.
Some considerations for future versions:
- Fluent options for setting an icon or colors on the fly
- Auto-dismissing option for flash messages
Credit for the original package goes to Jeffrey Way and Laracasts. Additional thanks:
- Caleb Porzio and his Livewire contributors for the awesome framework
- Adam Wathan and the Tailwind crew
- Taylor Otwell and co. for Laravel
This is an MIT-licensed package. Please read license.md for the details.