Adding AlertContainer Livewire component.
This commit is contained in:
parent
7712a4aad2
commit
fa002d5e08
2 changed files with 63 additions and 0 deletions
58
app/Http/Livewire/AlertContainer.php
Normal file
58
app/Http/Livewire/AlertContainer.php
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Livewire;
|
||||||
|
|
||||||
|
use Illuminate\Support\Facades\Session;
|
||||||
|
use Livewire\Component;
|
||||||
|
|
||||||
|
class AlertContainer extends Component
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* List of alert types.
|
||||||
|
*/
|
||||||
|
protected array $_types = [
|
||||||
|
'info',
|
||||||
|
'success',
|
||||||
|
'warning',
|
||||||
|
'danger'
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Event listeners
|
||||||
|
*/
|
||||||
|
protected $listeners = [
|
||||||
|
// Add message when "alert" event is fired.
|
||||||
|
'alert' => 'addMessage'
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Alert messages.
|
||||||
|
*/
|
||||||
|
public array $messages = [];
|
||||||
|
|
||||||
|
public function mount()
|
||||||
|
{
|
||||||
|
// Load messages from session
|
||||||
|
foreach($this->_types as $type) {
|
||||||
|
if (Session::has($type)) {
|
||||||
|
$this->addMessage($type, Session::get($type));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a message to the container.
|
||||||
|
*/
|
||||||
|
public function addMessage(string $type, string $message)
|
||||||
|
{
|
||||||
|
$this->messages[] = [ $type, $message ];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Render the messages
|
||||||
|
*/
|
||||||
|
public function render()
|
||||||
|
{
|
||||||
|
return view('livewire.alert-container');
|
||||||
|
}
|
||||||
|
}
|
||||||
5
resources/views/livewire/alert-container.blade.php
Normal file
5
resources/views/livewire/alert-container.blade.php
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
<div class="absolute z-50 top-0 w-full px-4 sm:px-8 space-y-2 mt-2">
|
||||||
|
@foreach($messages as $message)
|
||||||
|
<x-notification variant="{{ $message[0] }}">{{ $message[1] }}</x-notification>
|
||||||
|
@endforeach
|
||||||
|
</div>
|
||||||
Reference in a new issue