oriondevelops / filament-greeter
A Filament plugin to greet your users.
Fund package maintenance!
oriondevelops
Installs: 2 255
Dependents: 1
Suggesters: 0
Security: 0
Stars: 9
Watchers: 1
Forks: 2
Open Issues: 0
Requires
- php: ^8.1
- filament/filament: ^3.0
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.9
- orchestra/testbench: ^8.0
- pestphp/pest: ^2.1
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
README
This Filament plugin is the sibling of nova-greeter that extends the default account widget and lets you:
- Give yourself and your users fancy titles
- Add a custom action
- Change welcome message
- Change avatar size
- Disable avatar
Installation
You can install the package via composer:
composer require oriondevelops/filament-greeter
Usage
You need to register the plugin with your preferred Filament panel providers. This can be done inside your PanelProvider
, e.g. AdminPanelProvider
.
<?php namespace App\Providers\Filament; use Filament\Panel; use Filament\PanelProvider; use Filament\Actions\Action; use Orion\FilamentBackup\BackupPlugin; use Orion\FilamentGreeter\GreeterPlugin; use Orion\FilamentFeedback\FeedbackPlugin; class AdminPanelProvider extends PanelProvider { public function panel(Panel $panel): Panel { return $panel // ... ->plugins([ BackupPlugin::make() ->queue('monitors'), // ... GreeterPlugin::make() ->message('Welcome,') ->name('Daenerys Targaryen') ->title('The First of Her Name, the Unburnt, Queen of Meereen, Queen of the Andals and the Rhoynar and the First Men, Khalisee of the Great Grass Sea, Breaker of Chains and Mother of Dragons') ->avatar(size: 'w-16 h-16', url: 'https://avatarfiles.alphacoders.com/236/236674.jpg') ->action( Action::make('action') ->label('Buy more unsullied') ->icon('heroicon-o-shopping-cart') ->url('https://buyunsulliedonline.com') ) ->sort(-1) ->columnSpan('full'), // ... FeedbackPlugin::make() ->sendResponsesTo(email: 'oriondevelops@gmail.com'), ]) } }
Message
->message(text: 'Welcome')
To determine the welcome message dynamically you can use a closure:
->message(text: fn() => auth()->user()->hasRole('Super Administrator') ? __('Welcome my lord') : __('Welcome'))
Time-Sensitive Greeting
->timeSensitive(morningStart: 6, afternoonStart: 12, eveningStart: 17, nightStart: 22)
The greeting message will change to "Good morning", "Good afternoon", "Good evening", or "Good night" based on the current time. You can omit the hour parameters to use the default times.
Title
->title(text: 'Administrator', enabled: true)
To change the title based on the user you can use a closure:
->title(text: fn() => auth()->user()->title)
Avatar
->avatar(size: 'lg', enabled: true),
Action
->action( Action::make('action') ->label('Buy more unsullied') ->icon('heroicon-o-shopping-cart') ->url('https://buyunsulliedonline.com') )
Customizing visibility
<?php namespace App\Providers\Filament; use Filament\Panel; use Filament\PanelProvider; use Orion\FilamentGreeter\GreeterPlugin; class AdminPanelProvider extends PanelProvider { public function panel(Panel $panel): Panel { return $panel // ... ->plugin( GreeterPlugin::make() ->visible(fn() => auth()->user()->can('view greeter')) // OR ->hidden(fn() => auth()->user()->cannot('view greeter')), ); } }
Examples
GreeterPlugin::make()
->message('Welcome')
->name("Rand al'Thor")
->title("Dragon Reborn, Coramoor, Car'a'carn, He Who Comes With the Dawn, Shadowkiller, King of Illian, Lord of the Morning")
->avatar(size: 'w-16 h-16')
->columnSpan('full')
->action(
Action::make('action')
->label('Reborn')
->color('danger')
->icon('heroicon-o-arrow-path')
->action(function () {
Notification::make()
->title('Reborn successfully')
->success()
->send();
})
),
GreeterPlugin::make()
->message('Welcome')
->name("Annatar")
->action(
Action::make('action')
->label('Gift a ring')
->color('warning')
->icon('heroicon-o-gift')
->action(function () {
Notification::make()
->title('Target deceived successfully')
->warning()
->send();
})
),
GreeterPlugin::make()
->avatar(enabled: false),
GreeterPlugin::make()
->timeSensitive()
->name('Ser Arthur Dayne')
->title('Sword of the Morning')
->avatar(size: 'w-16 h-16')
->columnSpan('full')
->action(
Action::make('action')
->label('Protect the Heir')
->icon('heroicon-o-shield-check')
->action(fn () => Notification::make()->title('You failed! You’ve been stabbed in the back.')->danger()->send())
),
Contributing
Please see CONTRIBUTING for details.
Security
Please review Security Policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.