In this post we will take a step by step look on how well we can format the emails sent using HTML and CSS through Power Automate
This is just a manual trigger flow.
I have taken two SharePoint lists for this process.
One is Invoice list and another is product list. The relationship between Invoice and Product list is one to many.
I have divided this process into 4 parts
- The logo and the Company name formatting
- The section that displays Invoice Number, Invoice Period, Invoice To and Total
- The table with header and data
- A small message that shows invoice due date
mailTo is a compose input which consists of hardcoded email address.
data:image/s3,"s3://crabby-images/575d5/575d5952497f219e16ef23880ac352b454fe40fd" alt=""
The logo and the Company name formatting
cssHeader includes below code
.colImg{float:left;width:30%;padding:16px;height:100px}
.colCompany{float:left;width:30%; height:100px}
*{box-sizing:border-box;}
contentHeader has below code
<div>
<div class="colImg">
<img src="https://wfiot2018.iot.ieee.org/files/2016/01/sample-logo@2x.png" alt="Logo" width="200" height="50"/>
</div>
<div class="colCompany"><br></div>
<div class="colCompany">
<h2><a href="https://docs.microsoft.com"> COMPANY NAME </a></h2>
</div>
</div>
data:image/s3,"s3://crabby-images/3f634/3f634c95e2168b35e03a3cc346dbb7ff2a8a3738" alt=""
The section that displays Invoice Number, Invoice Period, Invoice To and Total
cssForSecondPart is a compose action that includes CSS for various invoice details
.col{float:left;width:20%;padding:2px;height:120px}
.colPara{font-size:0.66em}
htmlForSecondPart is a compose action that includes html outline for various invoice details.
In this part, replace the content between @{} to that of your content
<div>
<div class="col">
<h5>Invoice Number</h5>
<p class="colPara">@{outputs('getInvoice')?['body/InvoiceNumber']}</p>
</div>
<div class="col">
<h5>Invoice Period</h5>
<p class="colPara">@{outputs('getInvoice')?['body/InvoicePeriod']}</p>
</div>
<div class="col">
<h5>Invoice To</h5>
<p class="colPara">@{outputs('getInvoice')?['body/InvoiceTo']}</p>
</div>
<div class="col">
<h5>Total</h5>
<p class="colPara">@{outputs('getInvoice')?['body/TotalCost']}</p>
</div>
</div>
data:image/s3,"s3://crabby-images/78456/78456f1fca165faf54dad814caed6af4ecdb7f38" alt=""
The table with header and data
cssForTable is a compose action which includes below code
td,th{
border:1px solid #ddd;
padding:0.66em;
}
Table{border-collapse:collapse;width:100%}
tr{font-size:0.66em;}
th{background-color:#80dfff;font-size:2em;font-weight:bold;}
body{background-color:#f5f5f0;}
data:image/s3,"s3://crabby-images/b3f32/b3f321a2fbda0b2f9174e909d001fa75dd9a3f55" alt=""
Take a Create HTML Table action.
From inputs include outputs(‘getItems’)?[‘body/value’]
Header includes values from ‘getItems‘ step
data:image/s3,"s3://crabby-images/879dc/879dc339094e584b700b5b75e1644ec4b2cd8800" alt=""
A short message that shows invoice due date
lastMessage is a compose action which includes HTML and CSS for a short message display
<p style="color:red;">Please pay your invoice by @{
formatDateTime(outputs('getInvoice')?['body/InvoiceDueDate'],'dd.MM.yyyy')}</p>
In this part, replace the content between @{} to that of your content
data:image/s3,"s3://crabby-images/40a46/40a462e6d0c1521ebae602e2c5747d7d8df1ad6b" alt=""
finalResult – Compose includes outputs from below actions
<!DOCTYPE html>
<html>
<head>
<style>
@{outputs('cssHeader')}
@{outputs('cssForTable')}
@{outputs('cssForSecondPart')}
</style>
</head>
@{outputs('contentHeader')}
@{outputs('htmlForSecondPart')}
@{body('Create_HTML_table')}
@{outputs('lastMessage')}
</html>
In this part, replace the content between @{} to that of your content
data:image/s3,"s3://crabby-images/e8023/e8023938ccf47041877775967c2059d83393338b" alt=""
Result
data:image/s3,"s3://crabby-images/cbc53/cbc537aae9d719cc4741afa61b46181d5d3cb0ba" alt=""
If you liked the post, please share it with others 🙂
Please feel free to comment if you are stuck in any step
Thank you for reading 🙂