dynamik-dev / laravel-mail-preview
A utility for viewing emails in your browser as you develop.
Fund package maintenance!
DynamikDev
Requires
- php: ^8.4
- illuminate/contracts: ^10.0||^11.0||^12.0
- spatie/laravel-package-tools: ^1.16
- spatie/php-structure-discoverer: ^2.3
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-ignore-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
This package is auto-updated.
Last update: 2025-06-27 19:44:10 UTC
README
A utility for viewing emails in your browser as you develop with Laravel. This package allows you to preview your mailables without actually sending emails, making it easier to develop and test your email templates.
// Make any mailable previewable class WelcomeEmail extends Mailable implements Previewable { public static function toPreview(): self { return new self(User::factory()->make()); } }
Then, view it instantly at 👀 http://your-app.test/mail/welcome-email
Table of Contents
Think of it like Factories for your emails.
How to use
1. Make Your Mailable Previewable
To make a mailable previewable, implement the Previewable
interface and add the toPreview()
method:
class WelcomeEmail extends Mailable implements Previewable { public static function toPreview(): self { return new self( User::factory(['name' => 'Chris Arter'])->make() ); } }
2. View Your Email Preview
Once you've made your mailable previewable, you can view it in your browser at:
http://your-app.test/mail/welcome-email
The URL slug is automatically generated from your class name:
WelcomeEmail
→welcome-email
OrderConfirmationMail
→order-confirmation-mail
TestMailable
→test-mailable
3. Custom Preview Slugs
You can also define a custom preview slug by adding a static property to your mailable:
class WelcomeEmail extends Mailable implements Previewable { public static string $previewSlug = 'welcome'; // ... rest of your mailable code }
Now you can access it at: http://your-app.test/mail/welcome
Installation
You can install the package via Composer:
composer require dynamik-dev/laravel-mail-preview --dev
The package will automatically register itself with Laravel.
Requirements
- PHP 8.4+
- Laravel 10.x, 11.x, or 12.x
Configuration
Publish the configuration file:
php artisan vendor:publish --provider="DynamikDev\MailPreview\MailPreviewServiceProvider"
This will create a config/mail-preview.php
file with the following options:
return [ // Enable or disable the mail preview 'enabled' => env('MAIL_PREVIEW_ENABLED', false), // The route prefix for the mail preview 'route_prefix' => env('MAIL_PREVIEW_ROUTE_PREFIX', 'mail'), // The path to discover mailables in 'discover_path' => env('MAIL_PREVIEW_DISCOVER_PATH', base_path('app')), ];
Environment Variables
To enable the mail preview, set MAIL_PREVIEW_ENABLED
to true
in your .env
file.
These are the available options:
MAIL_PREVIEW_ENABLED=true MAIL_PREVIEW_ROUTE_PREFIX=mail MAIL_PREVIEW_DISCOVER_PATH=/path/to/your/app
Security
Important: This package should only be enabled in development environments. The mail preview routes expose your email templates and could potentially leak sensitive information.
Make sure to:
- Set
MAIL_PREVIEW_ENABLED=false
in production - Add the preview routes to your middleware if needed
- Consider using authentication middleware for the preview routes
Testing
Run the test suite:
composer test
Contributing
Please see CONTRIBUTING.md for details.
Credits
License
The MIT License (MIT). Please see License File for more information.