Loading...

Round Robin assignments in Power Automate

Round Robin assignments in Power Automate

When distributing tasks or tickets across a team, fairness matters, and so does flexibility. With Power Automate, we can implement a round robin pattern that always picks the next person in line, and wraps around once we hit the last.

I got asked by a customer on how to achieve this - so it might be helpful to you as well.

What we’re solving

Let’s say your team handles incoming forms—support requests, process suggestions, or tickets. You want those distributed evenly across your team, but also automatically.

The round robin logic makes sure that in a team 3 people:

Request # Assigned to
1 Person 1
2 Person 2
3 Person 3
4 Person 1 again

… and so on. No skipping, no duplication, no manual effort.

Setup

SharePoint list: AssignmentIndex

Create a simple list called AssignmentIndex. It only needs one row and one column (besides the Title):

Title LastIndex
Assignment 0
  • LastIndex must be a number column
  • This acts as memory across runs, telling us who got the last task

Microsoft Forms form

Set up a basic form with questions like Title, Description or similar. We will use this to trigger an upcoming support request.

Flow overview

flow overview

Let’s break this down into steps:

Microsoft Forms trigger

Use the trigger When a new response is submitted

Get Form Details

Use the actions: Get response details, this gives us the data we want to assign: title, description, urgency, etc.

Initialize MemberList

  • variable of type Array
  • leave value empty

Get SharePoint Index

Use Get items to pull the one row from the AssignmentIndex list. Use a filter condition Title eq 'Assignment'.

Initialize LastIndex

Now initialize a variable of type Float: body('Get_items_-_AssignmentIndex')? ['value'][0]?['LastIndex'] - this lets us store the value of the LastIndex column.

Get Microsoft Teams members

Use the action List members from Microsoft Teams connector to list the members of your Team. Select a team and channel from the dropdown. The output will be an array of team members (emails, names, etc.).

Get the email addresses

Add an Apply to each loop with the input: body('List_members')?['value']. Inside of the loop, add an Append to array variable - Choose the MemberList from the dropdown and put this into the value as an expression: items('Apply_To_Each')?['email']

This will loop through the array of objects we get from the Teams action, extract only the email addresses of the team members and add them to our array variable.

Calculate the new index

We now want to move one step/person forward in the team list. Initialize another variable NewIndex of type Float and use an expression:

mod(add(variables('LastIndex'), 1), length(variables('MemberList')))

This is where the magic happens. The mod() (Modulo) function will return the remainder of a division (dividend : divisor). In our case, it will give us the remainder of the division of LastIndex + 1 and the amount of items we got from the Memberlist variable (we calculate this with the length function).

What does mod() do here?

Let’s make that clear with a table:

LastIndex Team size NewIndex calculation Result
0 3 (0 + 1) mod 3 = 1 1
1 3 (1 + 1) mod 3 = 2 2
2 3 (2 + 1) mod 3 = 0 0

The mod() function ensures we loop back to the beginning after reaching the end of the list.

Now let’s finally find the right person to assign the new task to. We already know the NewIndex, all is left for us now is to get the NewIndexth (sic!) item from our MembersList: Add a Compose action and call it Assignee. Use this expression: variables('MemberList')[int(variables('NewIndex'))], which will then return the email address, and due to our round-robin logic it will always be the next person in the list. You might have noticed, that we make an integer out of our float variable - this is needed because the index needs to be an integer (as an index can’t be 9 3/4 or similar).

Assign the task

You can use this pattern for different use cases, for example

  • Assigned To fields (Planner, SharePoint, Approvals)
  • Emails
  • Logging

Do as you please, your Assignee action is now always the correct person.

Update the SharePoint index

Finally, don’t forget to update the LastIndex field in SharePoint List so we know who got the last assignment and the list stores the correct value for the next flow run.

Use Update item with:

  • ID = dynamic content ID from our Get items action
  • LastIndex = variables('NewIndex')

Done! 👌

Looking for more blog posts on Power Automate? I got you: https://www.m365princess.com/categories/power-automate/

Published on:

Learn more
Luise Freese: Consultant & MVP
Luise Freese: Consultant & MVP

Recent content on Luise Freese: Consultant & MVP

Share post:

Related posts

How to Automate Document Signing with DocuSign in Power Automate

Introduction In an earlier Inogic post, “Streamlining E-Signatures in Multi-Step Forms with Power Pages and DocuSign Integration”, Our previou...

2 hours ago

Power Automate Retry and Error Handling Patterns for Reliable Power Pages Integrations

When Power Pages integrates with Power Automate, reliability becomes key. Portal users expect instant responses — whether submitting a form, u...

2 days ago

Handling Large Files in Power Automate

Power Automate can handle large files, but how large? SharePoint Online supports files up to 250 GB, which sounds generous until you try movin...

2 days ago

UTCNow and that little hidden feature in Power Automate

If you have been following my posts on SharePains.com, then you will know about the UTCNow function generating the current UTC time. But did y...

2 days ago

Understanding Binary and Base64 in Power Automate

If you work with Power Automate and deal with files, you’ve encountered issues saving them. If you see things like “String/bytes i...

8 days ago

How to Auto-Fill Third-Party Web Forms Using Power Automate Desktop and JavaScript

In today’s digital workflows, teams across HR, operations, finance, and support deal with repetitive manual tasks every day. One of the most c...

9 days ago

How to Design Custom Approval Buttons in Outlook Email Using Power Automate (Step-by-Step Guide)

Microsoft’s standard approval emails make it easy to send and capture user feedback directly through Outlook. However, one major limitation is...

11 days ago

We need to talk about... Power Automate... Licensing

Next in my blog, I am going to cover a topic that has come up several times in recent conversations with clients.....Microsoft Licensing! part...

14 days ago

Flows getting triggered multiple times / missing callbackregistration record – Power Automate / Dataverse

Recently, we observed that one of our flows was getting triggered multiple times in our UAT environment; however, the flow was working properl...

15 days ago

Power Automate – Information about ‘Retry with AI vision’ functionality in Power Automate for desktop

We are announcing the introduction of the Retry with AI vision feature in error handling for UI and browser automation within Power Automate f...

16 days ago
Stay up to date with latest Microsoft Dynamics 365 and Power Platform news!
* Yes, I agree to the privacy policy