Kirby Courier
offers a convenient and painless solution for creating emails tailored for your Kirby
website.
With Kirby Courier
, you can streamline the process of email design and implementation for your site.
Download and copy this repository to /site/plugins/kirby-courier
.
composer require beebmx/kirby-courier
Kirby Courier
comes with two email message
types, and you can customize them for your convenience.
The Notification
message is the easiest way to send an email. You only need to use the Beebmx\KirbyCourier\Notification\Message
class
in your controller
or in your own implementation. Here's an example:
use Beebmx\KirbyCourier\Notification\Message;
(new Message)
->to('john@doe.co')
->line('Welcome to Kirby Courier')
->action('Visit', 'https://beeb.mx')
->send()
You have several methods to customize your Notification
message.
Here's an example with all the methods:
use Beebmx\KirbyCourier\Notification\Message;
(new Message)
->to('john@doe.co')
->greeting('Hello friend!')
->line('Welcome to Kirby Courier')
->line('You can add more lines before an action')
->lines(['Multiple line 01', 'Multiple line 02'])
->lineIf($someCondition === true, 'You can add more lines before an action')
->linesIf($someCondition === false, ['Line 03', 'Line 04'])
->success() // To set the action button as successful
->error() // To set the action button as an error
->action('Action button', 'https://beeb.mx')
->line('You can add lines after an action')
->salutation('Good bye!')
->send()
Warning
You can only add one action
per Notification
message.
The Mail
message is the easiest way to send an email if you need to customize all the body of your email, you only need to use the Beebmx\KirbyCourier\Mail\Message
class
in your controller
or in your own implementation. Here's an example:
use Beebmx\KirbyCourier\Mail\Message;
(new Message)
->to('john@doe.co')
->template('marketing')
->send()
Note
It's important that you set a template
to display your own customization.
Every template should be located in your courier
directory.
To create your own template
for your mail
messages, you need to create a file in the default location for Kirby Courier
.
Here's an example for a marketing message:
/*** /site/template/courier/marketing.php ***/
<?php snippet('courier/message', slots: true) ?>
<?php slot('body') ?>
# Hello Courier
The body of your courier message.
<?php snippet('courier/button', ['url' => ''], slots: true) ?>
Button
<?php endsnippet() ?>
Thanks,
<?= site()->title() ?>
<?php endslot() ?>
<?php endsnippet() ?>
Note
You can add content as markdown
and it will be processed by kirbytext
.
For both Notifications and Mail messages, there are shared methods. Here's an example with all the methods:
use Beebmx\KirbyCourier\Mail\Message;
(new Message)
->preset('contact') // The preset should be available in your config.php file
->from('no-reply@example.co')
->from('no-reply@example.co', 'Webmaster') // You can add a name to from address
->to('john@doe.co')
->to('jane@doe.co') // You can add multiple recipients (TO)
->cc('john@doe.co')
->cc('jane@doe.co') // You can add multiple recipients (CC)
->bcc('john@doe.co')
->bcc('jane@doe.co') // You can add multiple recipients (BCC)
->replyTo('john@doe.co')
->subject('Thank you for your contact request')
->theme('dark') // The theme should be available in your themes
->data(['name' => 'John Doe', 'position' => 'CEO']) // All the data available for the template
->attach($page->file('image.jpg'))
->attach($page->file('file.pdf')) // You can add multiple files
->attachMany([$page->file('file.pdf'), $page->file('file.jpg')])
->render() // Returns a Content instance to visualize
->send() // Trigger to send the email
If you want to previsualize your email, you can do it in any template. Here's an example:
<?= (new Beebmx\KirbyCourier\Mail\Message)
->template('marketing')
->data(['name' => 'John Doe'])
->render()
->toHtml() ?>
Note
The render
method doesn't trigger any email, and doesn't require any email settings
like subject
, from
or to
.
For your convenience, Kirby Courier
has some snippets
to speed up your email building flow.
You can add them in your courier template
.
Note
You can create your own snippets
if you want and apply it to the courier/message
snippet.
Just be sure to add it in the slot('body')
.
<?php snippet('courier/button', ['url' => ''], slots: true) ?>
Button
<?php endsnippet() ?>
<?php snippet('courier/panel', slots: true) ?>
This is a panel
<?php endsnippet() ?>
<?php snippet('courier/table', slots: true) ?>
| Content | Info | Currency |
| ------------ | :-----------: | --------: |
| Content 01 | Centered | $100 |
| Content 02 | Is centered | $150 |
<?php endsnippet() ?>
<?php snippet('courier/subcopy', slots: true) ?>
This is a subcopy
<?php endsnippet() ?>
If you are a Kirby CLI user, Kirby Courier
also has you covered.
The Kirby Courier
commands can help you create Mail
messages faster or even create your own Courier Theme
.
You can create your Mail
template with:
$ kirby make:courier <template>
$ kirby courier:make <template>
Note
courier:make
is an alias of make:courier
Or may be you want to customize your messages with your own theme
with:
$ kirby courier:theme <theme>
If dealing with namespaces
is hard, or you feel confused using the same Message
class name,
you can simplify it with the courier
helper:
For Notification
message you can use:
courier('notification')
->to('john@doe.co')
->line('This is a line')
->send()
For Mail
message you can use:
courier('mail')
->to('john@doe.co')
->template('marketing')
->send()
And of course, you can use it in a template
to render it:
<?= courier('mail')
->template('marketing')
->render()
->toHtml() ?>
Option | Default | Type | Description |
---|---|---|---|
beebmx.kirby-courier.logo | null | Closure ,string ,null |
Set your own logo in every message. |
beebmx.kirby-courier.path | courier | string |
Set a path where the templates and themes are located. |
beebmx.kirby-courier.from.address | 4 | int |
Set the default form.address for every message. |
beebmx.kirby-courier.from.name | 2 | int |
Set the default form.name for every message. |
beebmx.kirby-courier.message.greeting | Hello! | string |
Set the default message.greeting for every message. |
beebmx.kirby-courier.message.rights | All rights reserved. | string |
Set the default message.rights for every message. |
beebmx.kirby-courier.message.salutation | Regards | string |
Set the default message.salutation for every message. |
beebmx.kirby-courier.message.subject | Message from courier | string |
Set the default message.subject for every message. |
beebmx.kirby-courier.message.notify | string |
Set the default message.notify for every message. |
|
beebmx.kirby-courier.message.brand_name | null | ?string |
Set the default message.brand_name for every message. |
Here's an example of a full use of the options from the config.php
file:
'beebmx.kirby-courier' => [
'logo' => function() {
return site()->file('logo.png');
},
'path' => 'courier',
'from' => [
'address' => 'hello@example.com',
'name' => 'Example',
],
'message' => [
'greeting' => 'Hello friend!',
'rights' => 'Copyrights.',
'salutation' => 'Thanks',
'subject' => 'Message from courier',
'notify' => 'Si tienes problemas para hacer clic en el botón, copia y pega la URL de abajo en tu navegador web.',
'brand_name' => null,
],
],
Licensed under the MIT.
Kirby Courier
is inspired by the Laravel Notifications and Laravel Mail.
- Fernando Gutierrez @beebmx
- Jonas Ceja @jonatanjonas
logo
- All Contributors