an advanced plugin to send, manage and track your email campaigns
Thank you for purchasing my item. If you have any questions that are beyond the scope of this help file, please use my knowledge base as starting point. Thanks so much!
The MyMail Newsletter Plugin for WordPress is an advanced plugin which sends, manages and tracks your email campaigns.
Visit the MyMail Newsletter Plugin Homepage
To get this plugin working you have to follow these steps
Please go to the Settings page and configure the plugin before you start sending your first campaign!
If you have successfully activated the plugin you can create your first campaing like a regular post. Click on "New Campaign" in the "Newsletter" Menu
First choose a title for your campaign. The subject could be the same as the title but it's totally up to you.
All templates are prepared for "Preheaders". Please see this section for more info about preheaders.
You can define the senders email address, name and the address people can reply to.
This how the template looks when you start a new campaign. There's currently no content except the header and the footer part
The optionbar is divided into 6 buttons:
To add new content you have to add new modules and fill them with content.
Click and select your desired module. It gets appended right before the footer of the newsletter.
You can also add a new module right before an existing module by clicking on the button on the right.
To rearrange modules drag the modules to the new position or click the up and down buttons.
To remove a single module click the button.
To add content simple click on the element. All editable elements are surrounded by a red dotted line:
You can add four types of content:
Some modules offer an button on the right side to insert whole posts including headline, content, button with link to the article and the feature images (if exists)
You can use different type of placeholder tags in your newsletter. Check out this section for more info.
You can change the colors of your newsletter with the color option on the right. Click the arrows to the right to reset each field or save your newly created color schema to reuse it later.
If you like to set up a background you can select one of the included background in the dropdown. To include your own background just upload them in the myMail directory located at
wp-content/uploads/myMail/backgrounds/
They will get prepended to the dropdown list.
If you don't like to embed images - which reduce the file size - you can uncheck the option as well
The Delivery Meta Box is separated into two options: Regular Campaign and Auto responder
A Regular Campaign is a campaign which get sent once to each subscriber. The receivers can get defined in the Receivers Meta Box
If you don't check the "Send this Campaign" checkbox you wont be able to send your campaign.
You can define any date in the future or leave the current date to send the campaign immediately when you hit the save button (Please check out the Cron Job section to know how campaigns get sent in MyMail)
To test your campaign with your email client enter your email and hit the send button.
Please check the Auto responder section for more information
On the Receivers Meta Box you can limit the receivers for the current campaign
You can either send to specific lists or send to all available subscribers (List doesn't matter)
Furthermore you can limit the Receivers by choosing several conditions.
To protect the webversion with a password simple add it to the given box. Users are forced to enter this password in order to see the web version
With auto responders you can send campaigns to subscribers after a specific time and after a certain event. There are six types of auto responders available:
Subscriber base auto responders a triggered if an event to a specific subscriber occurs. A mail is sent only to a single subscriber if it matches the conditions and is in at least one list.
There are two events when this autoresponder is used
Create a new auto responder campaign like a regular campaign and select the autorespnder tab in the Delivery box
Now you can define when the autoresponder get send after which event. Furthermore you can define some conditions which must be true before the campaign get sent.
In this example the autoresponder campaign get send 30 days after user signed up
You can also check your custom field which you can define on the "Subscriber" tab in the settings.
Action based auto responders are usefull if you would like to send your latest post to your subscribers right after they get published.
You can send any post type including custom post types.
In this example an new campaign - based on the auto responder - is created after a new Post as been published but only if the post was published in any Category or with any Tag or as any Format which basically means every single post.
Please note that always 2 releases should get skipped. That means that the campaign doesn't get created until you have published the third post with the matching conditions.
You can use the {issue}
tag anywhere in your auto responder campaign to count them. This number get increased once a new copy of the campaign has been created.
The counter at the bottom shows the amount of already published posts and is used to calculate the skipped property. You can check the reset counter checkboy and save the campaign to reset the number.
To send a campaign with an interval (like daily, every week or yearly) you need time based auto responders
If you like to send Birthday wishes you have to choose this type of autoresponder.
If you like to send a follow up campaign after a subscriber opens a campaign or clicks a link you need this type of auto responder
If you have a custom application and need to send a campaign when a certain event get triggered you can choose this type.
Call the do_action('your_custom_hook')
method to trigger this campaign.
You can add the ID of a subscriber to send the campaign only to the passed IDs:
do_action('your_custom_hook', $ID)
or
do_action('your_custom_hook', array($ID1, $ID2,...))
This is how your autoresponder campaign can look like:
You notice many dynamic tas which get replaced when the campaign get sent.
A dynamic tag is wrapped in brackets like the other tags and start with the post type followed by an underscore and the content to display. After a colon can be a negative integer like -3 which represents the third latest entry of the selected post type.
{post_title:-1}
➨ displays the latest post title{page_title:-4}
➨ displays the fourth latest page title{post_image:-1}
➨ displays the feature image of the latest posts{post_image:-4|23}
➨ displays the feature image of the fourth latest posts. Uses the image with ID 23 if the post doesn't have a feature image{post_content:-1}
➨ displays the latest posts content{post_excerpt:-1}
➨ displays the latest posts excerpt or content if no excerpt is defined{post_date:-1}
➨ displays the latest posts date
{post_title:23}
➨ displays the post title of post ID 23{post_link:15}
➨ displays the permalink of post ID 15Instead of "post_" and "page_" you can use custom post types too
Depending on your delivery date and if you have marked the campaign to delivery, each campaign can have up to five statuses.
If a campaign was saved without the "Send this campaign" checkbox checked or a running campaign as been paused
If the campaign is waiting for dispatch
If the campaign is progression or right before to send
If all newsletters where sent the campaign is "finished" the date shows when the campaign has been finished
If you duplicate a campaign it's initial status is "Draft"
At the table view of the campaigns you get an overview of your campaigns
The Frontpage displays your newsletter as a "webversion". It provides a top bar with a link to your homepage, the title of the displayed campaign, a next and previous button to display the next or previous campaign (if exists), an optional share button and a button to close the frame.
With the share button users can share the newsletter via different social media services, bookmark services, via email or via link
You can create a custom frontpage and include it in your themefolder.
copy the single-newsletter.php
file located at
wp-content/plugins/myMail/views/single-newsletter.php
to the root directory of your theme folder. Now you can modify the code and add additional stylesheets to the page.
The plugin will automatically choose this template to display the webversion of the newsletter
You can expand up to four section to reveal more details:
Gives you a detailed list of all receivers. Subscribers which haven't received the campaign yet are not included. You can filter the list and define the ordering
Overview of clicked links, including amount and percentage starting with most clicked links.
Overview of used Devices and version. All devices are devided in either Desktop, Mobile or WebClient
Geo Location
Provides an overview of the location where your campaings has been openend *. You can click on an individual country to get the city data (requires track geo lcoations in the settings)
* Geodata is provided by Maxmind.com
You can find small boxes over the links which were clicked. More clicks means a higher percentage.
You can use two types of widgets in MyMail
Display you signup form within your sidebar or any other widget ready area. You can use the form which should get displayed and the title of the widget.
Furthermore you can define a static text before or after the form
Dispaly links to your most recent campaigns. Choose the number to limit the results. Campaings must either be active or finished to get displayed
MyMail Newsletter Plugin allows you to manage subscribers from the Subscribers overview page.
If you activate your plugin you'll find only the first and the last name field for the contacts. The users image is provided by gravatar.com.
To add more custom field you have to open the "subscribers" tab on the newsletter settings page.
You can make each custom field required and it will be displayed on the subscription form on your website. Use the tag to use this data in your newsletter.
MyMail Subscribers and WordPress Users can work closely together in MyMail. There's a dedicate settings page to define all options.
To keep data of your WordPress Users and your subscribers in sync you can define which fields should get synchronized when data has been updated
You can manually sync them for existing Users/subscribers as well To add Users automatically to you subscribers you have three options
MyMail can add new WordPress Users to your subscribers list
Add the User if he sign ups to your blog via the native registration form provided by WordPress
appends a checkbox for users who add a comment to your blog entries
All users added via the backend or with a third party plugin.
If you have a list of subscribers you can simple import them on the "Manage Subscribers" page.
You can either upload your CSV file or paste the content directly from Excel into the textarea on the right
If you data has been uploaded to your server you get a raw preview of your contacts.
You can define to which list you like to add the subscribers and the status they get when they are imported. If you choose "pending" all imported contact will receive an opt-in message to confirm their subscription)
If an subscriber already exits you can choose between three options how MyMail handle the import:
After the import has been finished you can see which emails are not imported.
You can export all of your subscribers into a CSV file. The file has to be prepared on your server and can take a while before it's accessible.
You can delete subscribers one by one or use this bulk delete option. Simple select which lists you would like to empty and click on the Delete Subscribers button. This cannot be undo!
The MyMail Newsletter Plugin comes with a flexible template. To get more templates check out this page
To upload a MyMail compatible template drag the ZIP file into the upload field
The subscribption form can be defined on the "Form" tab in the settings.
All forms are cached and comes default classes. Depending on your settings the form markup is this:
<form action="" method="post" class="mymail-form mymail-form-submit" id="mymail-form-X"> <div class="mymail-form-info"> </div> <div class="mymail-email-wrapper"> <label for="mymail-email-X">Email <span class="required">*</span></label><input id="mymail-email-X" name="userdata[email]" type="text" value="" class="input mymail-email required" tabindex="1"> </div> <div class="mymail-firstname-wrapper"> <label for="mymail-firstname-X">First Name</label><input id="mymail-firstname-X" name="userdata[firstname]" type="text" value="" class="input mymail-firstname" tabindex="2"> </div> <div class="mymail-lastname-wrapper"> <label for="mymail-lastname-X">Last Name</label><input id="mymail-lastname-X" name="userdata[lastname]" type="text" value="" class="input mymail-lastname" tabindex="3"> </div> <div class="mymail-custom-field-wrapper"> <label for="mymail-custom-field-X">Custom Field</label><input id="mymail-custom-field-X" name="userdata[custom-field]" type="text" value="" class="input mymail-custom-field" tabindex="4"> </div> <div class="mymail-lists-wrapper"> <label>Lists</label> <ul> <li><label title="Description"><input class="mymail-list-wordpress-users" type="checkbox" name="lists[]" value="wordpress-users" checked> Wordpress Users <span class="mymail-list-description mymail-list-description-wordpress-users">Description</span> </label></li> <li><label title=""><input class="mymail-list-2nd-list" type="checkbox" name="lists[]" value="2nd-list" checked> 2nd List</label></li> </ul> </div> <div class="mymail-submit-wrapper form-submit"> <input name="submit" type="submit" value="Subscribe" class="submit-button button" tabindex="5"> </div> </form>
There are three ways to embed the form:
[newsletter_signup_form id=X]
shortcodemymail_form( $id = 0, $tabindex = 1, $echo = true, $classes = '' );
function in your codePreheaders are small phrases (up to 80 letters) which should help increasing your clickthrough rate. Many email clients display the first letters of an email in their preview area.
Preheaders are invisible in the normal email view and show up only in the preview pane of some clients
MyMail is internationalized. You can find all available languages on the
Help translating the plugin or add your language in the next update!
There are some extensions available for MyMail:
All of your campaigns are sent via a cronjob. There are two cron services available:
This is the cron service which is built right into WordPress. If you choose this option you don't have to set up anything else to get your campaign sent. You only have to visit your blog (backend or frontend) regularly to trigger the cron.
Read more about the WordPress cron service here
Much better is a real cron service offerd by your hosting provider.
You have to call a specific URL which looks like:
http://yourwebsite.tld/wp-content/plugins/myMail/cron.php?735f0e3ab63d7d88b9f8dd10539b8a4c
You can find your URL in the Newsletter Settings page within the "Cron" tab
There are also some free service out there:
You can check for MyMail 2+ with
if(function_exists('mymail'){ //do stuff with MyMail 2.x }else{ //do stuff with MyMail 1.x }
Adding new subscribers in MyMail 2 works with the "add" method of the subscribers class.
$subscriber_id = mymail('subscribers')->add($entry, $overwrite);
$subscriber_id
holds the ID of the inserted subscriber or a WP_Error object if it fails.
$entry
can be a single email as string or a assoc array with field => values pairs
$overwrite
overwrites the subscriber with the same email if exists
$subscriber_id = mymail('subscribers')->add(array( 'fistname' => 'John', 'lastname' => 'Doe', 'email' => 'john.doe@example.com', 'status' => 1, //1 = subscribed (default) , 0 = pending, 2 = unsubscribed, 3 = hardbounced 'custom-field' => 'Custom Value', 'referer' => 'Your referer' //default = $_SERVER['REQUEST_URI'] ... ), $overwrite );
To assign lists you can use the assign_lists method like
$success = mymail('subscribers')->assign_lists($subscriber_ids, $lists, $remove_old = false);
$subscriber
_ids is either a single id or an array with id’s of subscribers
$lists
is either a single id or an array with id’s of lists
$remove_old
will remove all assigned lists before assigning the new once $success is boolean
To work with lists you can use the Lists class with mymail('lists')
Get a list of all lists
$lists = mymail('lists')->get();
a list object look like
( [ID] => 2, [parent_id] => 0, [name] => 'Wordpress Users', [slug] => 'wordpress-users', [description] => 'The description', [added] => 1411541385, [updated] => 1411541385 )
To get a single list add the $ID
as first argument:
$my_lists = mymail('lists')->get($ID);
This is a quick example how to implement a subscribe feature to your plugin
//check if MyMail 2 exits if(function_exists('mymail'){ //prepare the userdata from a $_POST request. only the email is rquired $userdata = array( 'email' => $_POST['email'], 'firstname' => $_POST['firstname'], 'lastname' => $_POST['lastname'], 'custom-field' => $_POST['custom-field'], 'referer' => 'Your referer', 'status' => 0, //0 forces a confirmation message .... ); $overwrite = true; //add a new subscriber and $overwrite it if exists $subscriber_id = mymail('subscribers')->add($userdata, $overwrite); //if result isn't a WP_error assign the lists if(!is_wp_error($subscriber_id)){ //your list ids $list_ids = array(123, 456); mymail('subscribers')->assign_lists($subscriber_id, $list_ids); }else{ //actions if adding fails. $subscriber_id is a WP_Error object } }
Here are some useful snippets to extend the functionality of MyMail:
function mystyle_function($color = 'black'){ return 'a{color:'.$color.' !important}'; } mymail_add_style('mystyle_function', 'red');
function mytag_function($option, $fallback, $campaignID = NULL, $subscriberID = NULL){ return 'My Tag: Option: '.$option."; Fallback: ".$fallback; } mymail_add_tag('mytag', 'mytag_function');
use: {mytag:option|fallback}
function mymail_submit_errors($object){ $object['errors'][] = 'new error'; return $object; } add_filter( 'mymail_submit', 'mymail_submit_errors' );
function mymail_form_fields($fields, $formid, $form){ $pos = count($fields) - 1; $fields = array_slice($fields, 0, $pos, true) + array("fieldID" => "Fieldcontent") + array_slice($fields, $pos, count($fields) - 1, true) ; return $fields; } add_filter( 'mymail_form_fields', 'mymail_form_fields', 10, 3 );
You can find the change log online here
I've used the following images, icons or other files as listed.
Files are maybe not included because of the license
Once again, thank you so much for purchasing this plugin. As I said at the beginning, I'd be glad to help you if you have any questions relating to this theme. No guarantees, but I'll do my best to assist. If you have a more general question relating to the themes on ThemeForest, you might consider visiting the forums and asking your question in the "Item Discussion" section.
Xaver Birsak – revaxarts.com