SparkPost Template

SparkPost 提供咗一個非常好用的 Template 功能,你可以花時間砌個靚靚仔仔嘅 html email 然後經過 Subsitution 將可變數據代入,成為一個獨一無二嘅電郵(personalized email),再經由 SparkPost 寄出,再利用 SparkPost 嘅 Tracking 功能,睇下個客喺收到電郵之後有咩反應。祇不過 html email content 就大有學問。

我哋嚟講講哩個 html email template 點做:

SparkPost 提供咗一個 template 例子(My First Email)俾你:

冇用嘅,可以忘記佢。

今時今日,html email 係要 responsive,即係好似網頁咁,用 desktop browser 同用手機﹑tablets 睇都會 ok 靚仔,唔會趕客。所以我哋要花心機搞 responsive html email。

由零開始係好難嘅,我哋去搵網友幫手,最好係 open sources 添:

  1. Simple HTML invoice template
  2. Responsive transactional HTML email templates

1 同 2 嘅 Billing email 差不多,不過 1 有用到 image,而 image 喺 html email 係有條件限制,因為怕咗啲 hacker,大部份 email client 都唔鍾意 email 入面有 image 嘅,咁,我哋就攞 1 嚟玩玩,向難度挑戰。

未加工前:

記住:

  • 一邊靠左,一邊靠右
  • 兩個 columns
  • Total 上面條線差不多到中間

SparkPost 冇得俾你上載你個 image file,我首先用 embedded image 方法:準備好你隻 image file,利用嚟個 online 服務 base64-image.de,上載你隻 image 然後請佢幫忙 convert:



一大堆符號,照抄就對了。首先 create 一個新 template 將個 open source html 抄哂入去,然後改一改個 image 嗰行,如圖:

再喺你個 program 發個 email 俾自己,我用 C#:

var transmission = new SparkPost.Transmission();
            transmission.Content.TemplateId = "invoice";    // xFilm5.Controls.Utility.Config.SparkPost_TemplateId_DN;
            //transmission.Content.From.Email = "support@directoutput.com.hk";
            //transmission.Content.ReplyTo = "no-reply<support@directoutput.com.hk>";

            transmission.SubstitutionData["first_name"] = "John Phillip";
            transmission.SubstitutionData["last_name"] = "Doe";
            /*
            var orders = new List<Order>
{
    new Order { OrderId = "1", Total = 101 },
    new Order { OrderId = "2", Total = 304 }
};

            // you can pass more complicated data, so long as it
            // can be parsed easily to JSON
            transmission.SubstitutionData["orders"] = orders;
            */
            var recipient = new SparkPost.Recipient
            {
                Address = new Address { Email = "paulusyeung@gmail.com" }
            };
            transmission.Recipients.Add(recipient);

            var client = new SparkPost.Client(xFilm5.Controls.Utility.Config.SparkPost_ApiKey);
            var response = client.Transmissions.Send(transmission).Result;
            // or client.Transmissions.Send(transmission).Wait();

收到會係咁樣嘅:

隻 image 出唔倒,啲 column formats 冇哂!😂

原因係 Gmail client 唔接受 embedded image 同 header CSS。自己搞 CSS,要將佢轉做 inline CSS,照慣例,先搵網上幫手:

將個 html template 抄俾佢,佢會幫你 convert 為 inline CSS,咁,你 create 多一個 template 照抄啲 code 就得。然後再發一個 email:

啲 formats 有番哂!接落嚟就到個 image,image 我會放喺 Google Drive,然後 share 條 link。

首先要用 admin account 去改啲設定,容許 anyone has the link can view the file. 然後上載隻 image file 去 Google Drive 做 share. 最後得到條 link,我哋淨係要個 id.

將第二個 html template duplicate 一個,將個 image 嗰行改成:

<img src="https://drive.google.com/uc?id=0BwWE4Iqoyigxek9UTW14VjBZZ2c" alt="linked logo" style="width:100%; max-width:300px;">

id= 你個 Google Drive file id,再 send 一個 email:

Desktop browser Gmail client Nexus 5X
iPhone 6 iPad

大功告成!(雖然未講點樣用 C# call SparkPost API 發電郵 😜)