cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
Yattering82
New Member

FLOW TO SEND EMAIL WHEN DATE APPROACHES

Hi there

 

This is the first time posting in the forum but a long time user of the forum. What I am trying to do, is to get a flow to trigger an sending an email when the date of a required audit approaches. The audit due dates are listed in a SharePoint list and you would think that this would be a simple thing to do. However, no matter how much I tinker and how much I see what others have done, I cannot get this to work.

 

This is what I have done:

 

@equals(item()?['Nextauditdue'], adddays(utcnow(),'mm-dd-yyyy')+14)

 

So basically I want this to send me an email when it is 14 days to the audit due date. 

 

If anyone can shed light on this, I would be most grateful.

117 REPLIES 117

I have tried using 'get items' instead of 'get files (properties only)' and again I do get the notification email but flow says it has failed. 

 

Here's what I see in outputs body ... I cannot see my 'Consent_x0020_End_x0020_Date' column in there as it happens. 

 

{
  "value": [
    {
      "@odata.etag""\"13\"",
      "ItemInternalId""6",
      "ID"6,
      "Personal_x0020_Info0": {
        "@odata.type""#Microsoft.Azure.Connectors.SharePoint.SPListExpandedReference",
        "Id"1,
        "Value""No"
      },
      "Personal_x0020_Info0#Id"1,
      "Purpose12": {
        "@odata.type""#Microsoft.Azure.Connectors.SharePoint.SPListExpandedTaxonomy",
        "TermGuid""030ec442-3c21-4d8e-bb6f-26c5d7e4735f",
        "WssId"189,
        "Label""Case study",
        "Path"null,
        "Value""Case study|030ec442-3c21-4d8e-bb6f-26c5d7e4735f"
      },
      "Purpose12#WssId"189,
      "products_x0020_and_x0020_services": {
        "@odata.type""#Microsoft.Azure.Connectors.SharePoint.SPListExpandedTaxonomy",
        "TermGuid""a67d7f16-fd3f-4f7d-8127-08d36c525c1d",
        "WssId"153,
        "Label""Benefactor",
        "Path"null,
        "Value""Benefactor|a67d7f16-fd3f-4f7d-8127-08d36c525c1d"
      },
      "products_x0020_and_x0020_services#WssId"153,
      "Organisation": {
        "@odata.type""#Microsoft.Azure.Connectors.SharePoint.SPListExpandedTaxonomy",
        "TermGuid""1a9c34ec-985b-4149-9445-ab4d2623cf56",
        "WssId"184,
        "Label""Jami & Jewish Care",
        "Path"null,
        "Value""Jami & Jewish Care|1a9c34ec-985b-4149-9445-ab4d2623cf56"
      },

 

Here is a shot of my doc library with workflow cols. Might be helpful to see these too.

doc library.png

 

Thanks again, Vicki

@Victoria

 

Hmm. I'm not sure what's going on. Your column names that show up in the picture are not showing up in the output results. To test things, I've created a new document library, put in two files and made a new column called Expiration with the type Date and Time.

 

Test Library.PNG

 

Then I made a Flow:

 

Flow.PNG

 

So it all worked with no errors. I connected to one of our SharePoint sites and a document library there under the Get File (properties only). Then I used the code we've been discussing to check the dates if the dates in the Expiration column is equal to today + 30 days:

 

@equals(formatDateTime(item()?['Expiration'], 'MM/dd/yyyy'), formatDateTime(addDays(utcNow(), 30), 'MM/dd/yyyy'))

And for me, that information showed up in the Output:

 

Output.png

 

Does any of that help?

 

Can you try renaming your Consent End Date column to just Consent and using the following code under the condition:

 

@equals(formatDateTime(item()?['Consent'], 'MM/dd/yyyy'), formatDateTime(addDays(utcNow(), 30), 'MM/dd/yyyy'))

Let me know if any of that helps! I'm using SharePoint Online with an Office 365 account.

 

Also, based on your picture below, can you double check if you have the Get Files (properties only) pointed to the right document library?

Hi again,
I've fully tested this now. The flow works perfectly if every document in the library has an end date. I added a date for all docs in the library to test.

 

So the flow definately has an issue when there is no date value in the consent end column. It does generate the email but says it fails, presumably when it gets to the records without dates.

I need to be able to run this on selected documents because not all library docs will need to be reviewed and added to the flow. Is there any way to exclude those without a date value or use my other (choice) column 'add to review'. All docs in flow would a 'yes' value in here which corresponds to those with consent end dates.

 

Thanks again for your help. Vicki

@Victoria

 

Awesome to hear that you Flow is working!

 

Okay, now we can make use of the code:

 

@not(empty(triggerBody()?['column name goes here']))

 

Just use the same column name that you used for the expiration condition and put a condition right under the Get Files (properties only).

 

So your Flow will check will check if the particular file has a date, if not it stops. If it does have a date, it'll check if the date is 30 days away from the target date in your column. If not, it stops. If yes, you get an e-mail.

 

Let me know if it works out!

Have done that. But flow still saying failed. Not sure if I am adding condition 2 in the right place?
1.png

 

2.png

@Victoria

 

I believe it should go

  • recurrence
  • get files (properties only)
  • apply to each
  • condition: if not empty
    • yes: date check
      • yes: send e-mail

 

 

Hi again, I really do appreciate you help and patience!

 

Do you mean in this format?


3.png

 

The flow now says it ran successfully however I'm no longer getting any emails. Checked 

 

4.png

Anonymous
Not applicable

Hey

 

This was extremely helpful to me! I just had a couple of additional questions to build on this.

 

In your formula, would the time be a 24hour or 12hour clock? Also would only the items within the '  ' comma's have to be replaced with actual figures?

 

 

Thanks in advance

 

 

Hi, 

Not sure what you mean about only the items within the '  ' comma's have to be replaced with actual figures.

The 'ConsentEnd' column is a 'date and time' column, although I am using it to log the date only, not time.

 

Thanks again, I really appreciate your efforts to help me.

 

Vicki

 

Anonymous
Not applicable

Hey,

 

I am sorry for not communicating my request clearly. I meant to ask which field in the following formula must be changed to make the formula useful.

 

@equals(formatDateTime(item()?['Nextauditdue'], 'MM/dd/yyyy'), formatDateTime(addDays(utcNow(), 14), 'MM/dd/yyyy'))

 

Sorry, quite new to SP and coding.

 

Thanks in advance

Hey @Anonymous,

 

This formula, as far as I know, does not care about the time or whether it's in 12 hour or 24 hour format. It just takes the date information. I have not tested what happens if you give it a Date and Time value.

 

@equals(formatDateTime(item()?['Consent'], 'MM/dd/yyyy'), formatDateTime(addDays(utcNow(), 30), 'MM/dd/yyyy'))

The code above has the word Consent in it. That is the column name that you'll want to change to your own column name. The whole original discussion is about how sometimes the name of the column that has spaces and it you need to give it this column name that SharePoint interprets it as. On page 1 and 2 of this discussion you can see that I was able to get the correct column name based on the the error that Flow returned.

 

Let me know if you have need more help!

@Victoria @Vix1

 

 

Hmm. So your first condition that is checking that things actually have values in them is returning a false value. Meaning, the Flow is not finding any values in the ConsentEnd column.

 

Where it says false in the screenshot below, can you go through and click the arrows inside the Apply to each step and see if you ever get a true?

Sorry about the delay, I was not working yesterday.

Arggh. This is driving me nuts! No, I don't have any matches in the Apply to each step.

Here is the doc library with data entries in the Consent End column...a.png

 

Here is the column name, so it is correct...

 

b.png

 

And this is the formula I've used..

@not(empty(triggerBody()?['ConsentEnd']))

 

Thanks you, Vicki

 

Hi @kristof805

Have finally got this going with help from the MS Flow team. Here's what we did.

There are some slight tweaks to the formula below.

 

condition1:@not(equals(items('Apply_to_each')?['ConsentEnd'], null))

condition2:@equals(items('Apply_to_each')?['ConsentEnd'], formatDateTime(addDays(utcNow(), 30), 'yyyy-MM-dd'))

 

flow working.png

 

Thank you for all your help. Vicki

Anonymous
Not applicable

Hey @kristof805

 

Thank you so much! You have been very helpful.

 

I was having slight issues with error messaged and I was wondering if you could clarify for me which end of the formula the current date is entered into (mm-dd-yyyy) ? I am operating under the assumption that the formula already knows that it needs to check for any items that expire within the next 30 days.

 

Also, would the date move forward everyday? Like if I set it as today's date, when the recurrence happens again tomorrow, will the code check for 30 days from tomorrows date? 

 

Thanks in advance!

@Victoria

 

So glad to hear it's working! I would not have figured out those combinations of formulas but I'm sure your post will be a good reference for others!

@Anonymous

 

The current date is entered into your columns on your SharePoint list or document library column. Then, the Flow checks if that date is exactly 30 days away (you can change this) every day. That's why it runs every day, so it checks for you, so you don't have to. On the day that your date in your column is 30 days away, you can have the Flow send an e-mail, some kind of warning, change something, etc.

Anonymous
Not applicable

@kristof805

 

Thanks! I tried running the flow and got this error message. Any suggestions?

 

Capture.PNG

@Anonymous

 

I believe that error is from the condition not finding a date. Do you have the name of your column with the right name? Do all items have a date in the date column? What do the other results say if you go forward or backward on "next failed" and "previous failed". Are they all indetical?

Anonymous
Not applicable

@kristof805

 

I have put the coloumn name where the formula earlier said Consent. The error shows all the information from the SP List so it is getting the data. All items have a date in the list. I have 60 items in the list, all have the same error message.

Helpful resources

Announcements

Super User of the Month | Drew Poggemann

As part of a new monthly feature in the Community, we are excited to share that Drew Poggemann is our featured Super User for the month of February 2024. If you've been in the Community for a while, we're sure Drew's name is familiar to you, as he is one of our most active contributors--he's been a Super User for five consecutive seasons!   Since authoring his first reply 5 years ago to his 514th solution authored, Drew has helped countless Community members with his insights and expertise. In addition to being a Super User, Drew is also a User Group leader and a Microsoft MVP. His contributions to our Super User sessions and to the new SUIT program are always welcome--as well as his sense of humor and fun-loving way of sharing what he knows with others.   When Drew is not solving problems and authoring solutions, he's busy overseeing the Solution Architecture team at HBS, specializing in application architecture and business solution strategy--something he's been doing for over 30 years. We are grateful for Drew and the amazing way he has used his talent and skills to help so many others in the Community. If you are part of the SUIT program, you got to hear some great tips from Drew at the first SUIT session--and we know he still has much more to share!You can find him in the Community and on LinkedIn. Thank you for all you do, Drew!

Announcing Power Apps Copilot Cookbook Gallery

We are excited to share that the all-new Copilot Cookbook Gallery for Power Apps is now available in the Power Apps Community, full of tips and tricks on how to best use Microsoft Copilot as you develop and create in Power Apps. The new Copilot Cookbook is your go-to resource when you need inspiration--or when you're stuck--and aren't sure how to best partner with Copilot while creating apps.   Whether you're looking for the best prompts or just want to know about responsible AI use, visit Copilot Cookbook for regular updates you can rely on--while also serving up some of your greatest tips and tricks for the Community. Our team will be reviewing posts using the new "Copilot Studio" label to ensure we highlight and amplify the most relevant and recent content, so you're assured of high-quality content every time you visit. If you share a post that gets featured in the curated gallery, you'll get a PM in the Community to let you know!The curated gallery is ready for you to experience now, so visit the new Copilot Cookbook for Power Apps today: Copilot Cookbook - Power Platform Community. We can't wait to see what you "cook" up!    

Celebrating a New Season of Super Users with Charles Lamanna, CVP Microsoft Business Applications

February 8 was the kickoff to the 2024 Season One Super User program for Power Platform Communities, and we are thrilled to welcome back so many returning Super Users--as well as so many brand new Super Users who started their journey last fall. Our Community Super Users are the true heroes, answering questions, providing solutions, filtering spam, and so much more. The impact they make on the Communities each day is significant, and we wanted to do something special to welcome them at our first kickoff meeting of the year.   Charles Lamanna, Microsoft CVP of Business Applications, has stressed frequently how valuable our Community is to the growth and potential of Power Platform, and we are honored to share this message from him to our 2024 Season One Super Users--as well as anyone who might be interested in joining this elite group of Community members.     If you want to know more about Super Users, check out these posts for more information today:    Power Apps: What is A Super User? - Power Platform CommunityPower Automate: What is A Super User? - Power Platform Community Copilot Studio: What is A Super User? - Power Platform Community Power Pages: What is A Super User? - Power Platform Community

Super Users 2024 Season One is Here!

   We are excited to announce the first season of our 2024 Super Users is here! Our kickoff to the new year welcomes many returning Super Users and several new faces, and it's always exciting to see the impact these incredible individuals will have on the Community in 2024! We are so grateful for the daily difference they make in the Community already and know they will keep staying engaged and excited for all that will happen this year.   How to Spot a Super User in the Community:Have you ever written a post or asked for help in the Community and had it answered by a user with the Super User icon next to their name? It means you have found the actual, real-life superheroes of the Power Platform Community! Super Users are our heroes because of the way they consistently make a difference in the Community. Our amazing Super Users help keep the Community a safe place by flagging spam and letting the Community Managers know about issues. They also make the Community a great place to find answers, because they are often the first to offer solutions and get clarity on questions. Finally, Super Users share valuable insights on ways to keep the Community growing, engaging, and looking ahead!We are honored to reveal the new badges for this season of Super Users! Congratulations to all the new and returning Super Users!     To better answer the question "What is a Super User?" please check out this article: Power Apps: What is A Super User? - Power Platform CommunityPower Automate: What is A Super User? - Power Platform Community Copilot Studio: What is A Super User? - Power Platform Community Power Pages: What is A Super User? - Power Platform Community

Did You Attend the Microsoft Power Platform Conference in 2022 or 2023? Claim Your Badge Today!

If you were one of the thousands of people who joined us at the first #MPPC Microsoft Power Platform Conference in 2022 in Orlando--or attended the second-annual conference in Las Vegas in 2023--we are excited to honor you with a special community badge! Show your support for #MPPC Microsoft Power Platform Conference this year by claiming your badge!           Just follow this link to claim your badge for attending #MPPC in 2022 and/or 2023: MPPCBadgeRequest    Want to earn your badge for 2024? Just keep watching our News & Announcements for the latest updates on #MPPC24.

Microsoft Power Platform | 2024 Release Wave 1 Plan

Check out the latest Microsoft Power Platform release plans for 2024!   We have a whole host of exciting new features to help you be more productive, enhance delegation, run automated testing, build responsive pages, and so much more.    Click the links below to see not only our forthcoming releases, but to also try out some of the new features that have recently been released to market across:     Power Apps  Power Automate  Copilot Studio   We can’t wait to share with you all the upcoming releases that will help take your Power Platform experience to the next level!    Check out the entire Release Wave: Power Platform Complete Release Planner 

Users online (2,682)