Browse files

Wrote an actual README.

  • Loading branch information...
hperrin committed May 15, 2018
1 parent 2c535da commit 88211e71af59e225c51c3872b604caa054d90469
Showing with 70 additions and 3 deletions.
  1. +70 −3
@@ -1,4 +1,71 @@
# µMailPHP
PHP email templating system.
An email templating system for Nymph.
## Installation
composer require sciactive/umailphp
npm install --save umailphp
uMailPHP is configured with the `\uMailPHP\Mail::configure()` static method. The configuration options are available in `conf/defaults.php`.
## Usage
// After creating the \MyApp\VerifyEmailDefinition class, which extends
// \uMailPHP\Definition, you can use it like this:
// Define any macros, and be sure to escape them with htmlspecialchars.
$link = htmlspecialchars(''.$someSecret);
$macros = [
'verify_link' => $link,
'start_date' => htmlspecialchars(\uMailPHP\Mail::formatDate(
'to_phone' => htmlspecialchars(\uMailPHP\Mail::formatPhone($user->phone)),
'to_group' => htmlspecialchars($user->group->name)
// Create the mail object. Second argument can either be an email address or an
// object with an 'email' property.
$mail = new \uMailPHP\Mail('\MyApp\VerifyEmailDefinition', $user, $macros);
// Send mail.
if (!$mail->send()) {
throw new \Exception('Email failed.');
## How It Works
uMailPHP constructs emails using three parts:
- The template.
- The mail definition.
- An optional custom redefinition called a rendition.
The **template** is used for each email that is sent. It provides the basic layout of the email. If you don't specify a template when sending an email, the first one that is enabled will be used. If you haven't defined any templates, a default one will be used.
The **mail definition** is a PHP class responsible for initiating the email. It provides the main content of the email. For example, the mail definition of an email sent when a new user registers would pertain to the user and may have their information in the body of the email. The definition of an email sent when a user makes a purchase could provide information about the purchase and a receipt.
A **rendition** is stored in the database. When defined, it's used in place of the mail definition to construct the body of the email. It can be created through the setup GUI, rather than hard coded to customize the email's content.
## How To Customize
The two ways you can customize the emails are by creating templates and renditions. When you create a template, you can design the overall look and design of all emails. When you create a rendition, you can customize a single type of email (like a new user registration email).
## Macros
The content in an email almost always includes variables, such as the recipient's name, which are handled by macros. A macro is just the name of a variable surrounded by hash symbols (e.g. #to_name#). This text is replaced before the email is sent.
There are universal macros, which can be used in any template, definition, or rendition. Also, there are macros specific to a mail definition. For example, the definition of an email sent when a user changes an appointment with a customer could have macros called #old_date# and #new_date#. When you create a rendition to customize the email, you can use these macros.
### Heads Up
When you format a macro, edit the macro string as a whole. If you want to bold it, change the whole string, including the hash symbols.
- Right: **#to_name#**, *#old_date#*
- Wrong: #**to_name**#, #*old_date*#

0 comments on commit 88211e7

Please sign in to comment.