alizharb / flare
A beautiful, performant toast notification package for Laravel Livewire with real-time support
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/alizharb/flare
Requires
- php: ^8.3
- illuminate/support: ^12.0
- livewire/livewire: ^3.5
Requires (Dev)
- laravel/pint: ^1.18
- orchestra/testbench: ^10.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/phpstan: ^2.0
README
Flare
Production-Ready Toast Notifications for Laravel Livewire
Elegant • Performant • Customizable
Features • Installation • Quick Start • Documentation • Themes • Examples
🎯 Overview
Flare is a modern, feature-rich toast notification system built specifically for Laravel Livewire applications. With zero configuration required and three distinct visual themes, Flare provides beautiful user feedback out of the box while offering extensive customization for advanced use cases.
// Simple, elegant API Flare::success('Profile updated successfully!'); // Full control when you need it Flare::warning( text: 'Session expires in 5 minutes', heading: 'Warning', duration: 10000, position: 'top center' );
✨ Features
📋 Requirements
| Requirement | Version |
|---|---|
| PHP | 8.3+ |
| Laravel | 12.0+ |
| Livewire | 3.5+ |
| Alpine.js | 3.x (included in Livewire 3) |
🚀 Installation
Step 1: Install via Composer
composer require alizharb/flare
Step 2: Publish Assets
IMPORTANT: Assets must be published for Flare to work.
php artisan vendor:publish --tag=flare-assets
Step 3: Add to Layout
<!DOCTYPE html> <html lang="en"> <head> @flareStyles {{-- Required --}} </head> <body> <flare::toasts /> {{-- Required --}} @flareScripts {{-- Required --}} </body> </html>
That's it! 🎉 You're ready to use Flare.
Optional Configuration
# Publish config file php artisan vendor:publish --tag=flare-config # Publish views for customization php artisan vendor:publish --tag=flare-views
⚡ Quick Start
Using the Facade
Perfect for controllers, services, and any PHP class:
use AlizHarb\Flare\Facades\Flare; class UserController extends Controller { public function store(Request $request) { User::create($request->validated()); Flare::success('User created successfully!'); return redirect()->route('users.index'); } }
Using the Livewire Trait
The easiest way in Livewire components:
use Livewire\Component; use AlizHarb\Flare\Concerns\WithFlare; class CreatePost extends Component { use WithFlare; public function save() { Post::create($this->validate()); $this->flareSuccess('Post published!', 'Success'); } }
Using JavaScript
For client-side notifications:
// Simple Flare.success("Item added to cart!"); // Advanced Flare.toast("Welcome back!", { heading: "Hello User", variant: "info", duration: 5000, position: "top center", });
🎨 Themes
Flare includes three professionally designed themes. Choose the one that fits your application's aesthetic.
All themes support light & dark modes automatically.
📚 Documentation
📖 Complete Documentation
Visit our comprehensive documentation:
- Introduction - What is Flare?
- Installation - Detailed setup guide
- Quick Start - Get started in 5 minutes
- Themes - Visual customization
- Configuration - All options explained
- Examples - Real-world scenarios
🌐 Interactive Docs
Run the documentation website locally:
php -S localhost:8000 -t docs
Visit http://localhost:8000 for interactive documentation.
💡 API Reference
Toast Variants
Flare::success($text, $heading = null, $duration = 5000, $position = null); Flare::warning($text, $heading = null, $duration = 5000, $position = null); Flare::danger($text, $heading = null, $duration = 5000, $position = null); Flare::error($text, $heading = null, $duration = 5000, $position = null); // Alias Flare::info($text, $heading = null, $duration = 5000, $position = null);
Livewire Trait Methods
$this->flareSuccess($text, $heading = null, $duration = 5000, $position = null); $this->flareWarning($text, $heading = null, $duration = 5000, $position = null); $this->flareDanger($text, $heading = null, $duration = 5000, $position = null); $this->flareError($text, $heading = null, $duration = 5000, $position = null); $this->flareInfo($text, $heading = null, $duration = 5000, $position = null);
JavaScript API
Flare.toast(text, options); Flare.success(text, options); Flare.warning(text, options); Flare.danger(text, options); Flare.error(text, options); Flare.info(text, options);
⚙️ Configuration
View Complete Configuration
return [ // Visual theme 'theme' => 'modern', // classic, modern, vibrant // Default position 'position' => 'bottom end', // Default duration (ms) 'duration' => 5000, // Stacking behavior 'enable_stacking' => true, 'stack_expanded' => false, 'max_visible' => 3, // Features 'icons' => ['enabled' => true], 'actions' => ['enabled' => true], 'priority' => ['enabled' => true], 'rate_limit' => ['enabled' => true], 'progress_bar' => ['enabled' => true], ];
Environment Variables
FLARE_THEME=modern FLARE_POSITION="bottom end" FLARE_DURATION=5000 FLARE_ENABLE_STACKING=true FLARE_STACK_EXPANDED=false
🎯 Examples
Form Validation
class ContactForm extends Component { use WithFlare; public function submit() { $this->validate([...]); // Send email... $this->flareSuccess( text: "Thank you! We'll get back to you soon.", heading: 'Message Sent', duration: 7000 ); } }
CRUD Operations
public function destroy(Post $post) { $post->delete(); Flare::danger( text: 'Post has been permanently deleted', heading: 'Deleted', duration: 4000 ); return redirect()->route('posts.index'); }
Persistent Notifications
// Requires manual dismissal Flare::danger( text: 'Critical error - please contact support', heading: 'Error', duration: 0 // Never auto-dismiss );
See EXAMPLES.md for more real-world scenarios.
⌨️ Keyboard Shortcuts
| Shortcut | Action |
|---|---|
Esc |
Dismiss most recent toast |
Shift + Esc |
Dismiss all toasts |
Alt + D |
Dismiss all toasts (alternative) |
🧪 Testing
Flare includes a comprehensive test suite:
# Run tests composer test # Run tests with coverage composer test:coverage # Run static analysis composer analyse # Run code style fixer composer format
Test Results: ✅ 12 tests, 22 assertions, 100% passing
🤝 Contributing
We welcome contributions! Please see CONTRIBUTING.md for details.
Development Setup
git clone https://github.com/alizharb/flare.git cd flare composer install composer test
📝 Changelog
See CHANGELOG.md for all changes and version history.
Latest Release: v1.1.0
- ✨ Three distinct themes (Classic, Modern, Vibrant)
- 🐛 Fixed all positioning issues
- ⚡ Improved stacking performance
- 🌍 Added RTL/LTR support
- 📚 Complete documentation
📄 License
Flare is open-source software licensed under the MIT License.
🙏 Credits
Built with ❤️ by Ali Harb
Special thanks to:
- Laravel & Livewire teams
- Alpine.js community
- All contributors
🌟 Support
If you find Flare useful, please consider:
- ⭐ Starring the repository
- 🐛 Reporting bugs
- 💡 Suggesting features
- 📖 Improving documentation
- 💰 Sponsoring development
Made with ❤️ for the Laravel community