{"id":111010,"date":"2019-06-12T08:00:02","date_gmt":"2019-06-12T15:00:02","guid":{"rendered":"https:\/\/www.microsoft.com\/en-us\/power-platform\/blog\/power-automate\/beginner-flow-of-the-week-early-meeting-reminder\/"},"modified":"2019-06-12T08:00:02","modified_gmt":"2019-06-12T15:00:02","slug":"beginner-flow-of-the-week-early-meeting-reminder","status":"publish","type":"power-automate","link":"https:\/\/www.microsoft.com\/en-us\/power-platform\/blog\/power-automate\/beginner-flow-of-the-week-early-meeting-reminder\/","title":{"rendered":"Intermediate | Flow of the Week: Early Meeting Reminder"},"content":{"rendered":"
Hi Flow Community!<\/p>\n
Have you ever missed an important meeting because it was before your normal work hours? This happened to me one too many times, so I decided to do something about it! My flow runs every night around 8 p.m. and sends me and email if I have a meeting before 10 a.m. the next day. This gives me time to change my alarm if needed or make other plans. 10 a.m. may not be \u201cearly\u201d to a lot of you, but these values are easy to change.<\/p>\n
Before I get into the implementation, if you only care about the solution, I\u2019ve created templates for Office 365 Outlook<\/a>, Outlook.com<\/a>, and Google Calendar\/Gmail<\/a>. I\u2019ll be walking through the Office 365 Outlook version, but the others are pretty much the same.<\/p>\n In theory this a straightforward flow, given the handy \u201cGet calendar view of events\u201d action. Get current time, add hours, get events, send an email. But of course time zones have to show up and complicate things. So let\u2019s break it down.<\/p>\n Here\u2019s the math-y part. \u201cGet current time\u201d uses UTC, so we have to convert it to local time to work properly with the startOfDay() function. It turns out that even though we specify the \u201cRound-trip [o]\u201d format, it loses the time zone information here, so we have to convert it back to UTC to be useful to the calendar action. We then add a day to get start of day tomorrow, then another 10 (or however many) hours to get the threshold for \u201cearly\u201d. These actions are also all available as functions if you\u2019d like to condense this part, but the actions make for a more readable and fillable template.<\/p>\n <\/p>\n NOTE: I didn\u2019t specify the minutes in my Recurrence trigger, meaning it will run sometime between 8:00 and 9:00. If you specify exactly 8:00 you can skip the time zone stuff and do +4h, +10h to get the range. This makes for a brittle template though because changing one value requires changing the others, and we have no real need to run exactly on the hour.<\/p>\n <\/p>\n This is the easy part. We pass the calculated times to \u201cGet calendar view of events action\u201d. For Outlook, we pass the \u201cisAllDay eq false\u201d filter because all-day events don\u2019t count as early. Google Calendar doesn\u2019t have an equivalent filter, so instead we use the \u201cFilter array\u201d action and check whether the start time has a \u201cT\u201d separator in it, indicating a specific start time vs. an all-day event.<\/span> We then check if there are any events in the array. Normal condition stuff.<\/p>\n <\/p>\n From here we could send an email that says \u201cEarly meeting! Go check your calendar!\u201d and call it quits. But where\u2019s the fun in that? Instead, let\u2019s convert the events to local time and put them in a more readable format for the email. You can skip the \u201cApply to each\u201d in favor of a \u201cSelect\u201d action here, but that doesn\u2019t let us leave the time zone blank for the template.<\/p>\n <\/p>\n Finally, we send the reminder email. Outlook.com and Gmail require you to type in your own email address, but Office 365 has a handy \u201cGet my profile\u201d action that saves you the trouble.<\/p>\n <\/p>\n That\u2019s it! Hopefully this flow helps keep your schedule running smoothly. Extra credit if you can get it to filter out an 11:00 a.m. Monday through 5:00 p.m. Friday event (not \u201call-day\u201d but multi-day), or to remind attendees of the early meeting you\u00a0<\/em>scheduled. Let me know in the comments if you have any feedback or if you have any cool timing or scheduling flows of your own.<\/p>\n","protected":false},"excerpt":{"rendered":" Have you ever missed an important meeting because it was before your normal work hours? Learn how to get reminder emails for early meetings using Microsoft Flow, and get a crash course in the joy of time zones at the same time.<\/p>\n","protected":false},"author":377,"featured_media":0,"comment_status":"open","ping_status":"open","template":"","power-automate-category":[2590,2836],"power-automate-tag":[2591,2638],"coauthors":[2946],"class_list":["post-111010","power-automate","type-power-automate","status-publish","hentry","power-automate-category-flow-of-the-week","power-automate-category-walkthroughs","power-automate-tag-flow-of-the-week","power-automate-tag-intermediate"],"yoast_head":"\n
\n<\/p>\n