sammyjo20 / wagonwheel
Offer an online version of your Laravel emails to users.
Fund package maintenance!
Sammyjo20
Installs: 5 263
Dependents: 0
Suggesters: 0
Security: 0
Stars: 247
Watchers: 6
Forks: 7
Open Issues: 1
Requires
- php: ^7.3|^8.0
- illuminate/console: ^8.0
- illuminate/database: ^8.0
- illuminate/http: ^8.0
- illuminate/mail: ^8.0
- illuminate/routing: ^8.0
- illuminate/support: ^8.0
- paquettg/php-html-parser: ^3.1
- swiftmailer/swiftmailer: ^6.2.1
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.16
- orchestra/testbench: ^6.0
- phpunit/phpunit: ^9.4
This package is auto-updated.
Last update: 2022-08-06 23:11:14 UTC
README
Thank you everyone for downloading Wagonwheel, however I am going to be formally abandoning the project.
This is was a collaborative project with Ryan Chandler. Please consider supporting him for the hard work he put into this package!
Help support the maintenance of this package by buying me a coffee.
Wagonwheel
Offer an online version of your Laravel emails to users.
-
Uses Laravel's built-in temporary signed URLs to create the URL for the online version. This means it's secured by your app's encryption key, as well as making it difficult to guess.
-
Highly customisable.
-
Easy to install.
-
Supports Laravel 8
Installation
- Install Wagonwheel using composer with the command below:
composer require sammyjo20/wagonwheel
- Publish the migrations
php artisan vendor:publish --tag=wagonwheel-migrations
- Run the migrations
php artisan migrate
- Add the "SaveForOnlineViewing" trait to any of your Mailables.
use Illuminate\Bus\Queueable; use Illuminate\Mail\Mailable; use Illuminate\Queue\SerializesModels; use Sammyjo20\Wagonwheel\Concerns\SaveForOnlineViewing; class BookingConfirmed extends Mailable { use Queueable, SerializesModels, SaveForOnlineViewing; /** * Build the message. * * @return $this */ public function build() { return $this->subject('Booking Confirmed 🎉') ->markdown('emails.bookings.confirmed'); } }
Configuration
If you would like to customise how Wagonwheel works. Run the following command to publish Wagonwheel's configuration file.
php artisan vendor:publish --tag=wagonwheel-config
component_placement - This configuration variable defines if the banner should be rendered at the start of the email content or at the end of the email content. The available values are start and end.
message_expires_in_days - This configuration variable defines how long Wagonwheel should keep the online version of an email in days. If you would like the online version of your emails to never expire, set this to 0. The default is 30 days.
Customisation
If you would like to customise how the banner looks inside the email, just publish Wagonwheel's views with the following command.
php artisan vendor:publish --tag=wagonwheel-views
Testing
Run all tests
composer test
Run a specific test
composer test-f [name of test method]
Thanks
- Ryan Chandler (@ryangjchandler) helped out massively with some great code improvements and overall making Wagonwheel better!
- Gareth Thompson (@cssgareth) helped out with coming up with a cool name!