Need to save an item and attachment file from one SharePoint list to another SharePoint list, based on a condition using Power Automate? check out this blog post.
In this blog post, I will show how you can achieve the goal that whenever an item is created in SharePoint list A and condition is met the item and attachment should be automatically saved in another SharePoint list (SharePoint list B) and the attachment will be saved as a link by using Power Automate.
The Power Automate flow is in this Repository, you can easily download (the zip file is PopulateCustomerSupportDatabase) and change the connections and connection reference in the trigger and actions to your SharePoint site and list.
Note: This step can be used where a SharePoint List are in the same SharePoint Site or where the SharePoint List are in different SharePoint Sites.
To illustrate the process, consider this example scenario:
Bank ABC operates a Customer Complaint Management System with various teams handling different categories of customer complaints.
They utilize the SharePoint list named 'Customer Complaints' and Customer Support Database.
Whenever a new item is added to the Customer Complaint SharePoint list and 'Alert' is chosen from the 'Type of complaint' choice column, the system automatically stores the data and any attached files from the 'Customer Complaints' SharePoint list into the 'Customer Support Database' SharePoint list.
Figure 1: This shows the result of when an item is created in SharePoint list A, it automatically saves the item and attachment (as a link) in SharePoint list B.
Disclaimer: This is not an actual bank, but a scenario I created.
-
When an item is created
-
Initialize variable
-
Condition
- Get Attachments
- Apply to each
- Get attachment content
- Create file
- Create sharing link for a file or folder
- Compose
- Append to string variable
- Create Item
In this context, the Customer Complaint SharePoint list will be referred to as SharePoint list A, and the Customer Support Database SharePoint list will be known as SharePoint list B. This distinction is intended to minimize confusion.
- Have a Power Automate license or access to use Power Automate.
- SharePoint Document Library (this will be used to save the attachment file gotten from SharePoint List A).
- A Multiple line of text column in SharePoint list B, where the text format is rich text. This column will be used to save the link of the attachment in SharePoint list B.
Note: We are using multiple lines of text data type here instead of a hyperlink data type column because we expect more than one Attachment file and the date this blog post was written, hyperlink data type column does not support more than one hyperlink URL.
-
Go to Power Automate
Figure 2: Power Automate Home Screen.
-
At the left-side of the screen, click on Create.
Figure 3: The Power Automate Home Screen displays a red arrow directing attention to 'Create' on the left side of the screen.
Figure 4: Power Automate Create Screen.
- At the middle of the screen, click on Automated cloud flow. Next, on Flow name add the name of the flow, here I will be using
Populate Customer Support Database.
On Choose your flow's trigger, select the trigger When an item is created. Next, click on the button Create, this is shown in figure 6.
Figure 5: A red arrow pointing to Automated cloud flow in the Power Automate Create screen.
Figure 6: Power Automate flow trigger: When an item is created. The arrow points where to write the flow's name, the trigger to choose, and where to click the button Create.
Figure 7: When an item is created trigger.
-
The trigger, 'When an item is created', select your SharePoint site and SharePoint list. Click on the drop-down icon next to Site Address to choose your SharePoint site, and then click on the drop-down icon next to List Name to select your SharePoint list.
Figure 8: A red arrow points to the selected SharePoint site and SharePoint list in the trigger when an item is created.
Note: The flow is triggered when an item is created in the Customer Complaint SharePoint list (SharePoint List A).
-
Click on +New step, search and add the action Initialize variable.
-
In the Name field of the Initialize variable action add a word text, here I used Attachment. change the type of the initialize variable to String, this is shown in figure 10.
-
Click +New step, then search and add the Condition action.
-
On the left-side of the Condition action "Choose a value". Go to the Dynamic content, search and add the column you wish to base your condition on. For this example, I will select "Type of Complaint Value" a choice column (this is coming from the trigger when an item is created).
Next, on Choose a Value on the right side, here I will write the text Alert as shown in figure 12.
Note: We have options in the 'Type of Customer Complaint' choice column, but in this case, I want the flow to execute under the condition that whenever an item is created in the Customer Complaint SharePoint list and 'Alert' is selected as the type of complaint, the item and its attachment should be saved to the Customer Support Database SharePoint list (SharePoint list B).
Next, in the Condition change 'Is equal to' to 'contains' as shown in figure 12.
Figure 12: A red arrow points to the Choose a value at the right-side of the Condition action and another red arrows point to the Dynamic content "Type of Complaint Value". In the middle of the Condition action, a red arrow points to contains and at the right side of the Condition action a red arrow points to the word "Alert".
-
In the If yes of the Condition action, click on Add an action. Search and add the action Get attachments. Here, we will getting the attachment saved in SharePoint List A. In the Get attachments action, on Site Address select your SharePoint site and on List Name, select your SharePoint list name.
Figure13: Get attachment action; a red arrow showing where the SharePoint site and list has been selected.
-
The Get attachments action; on Id field go to the Dynamic content and search and select ID (this is coming from the trigger, when an item is created), this is shown in figure 14.
Figure 14: A red arrow points to the Dynamics Content ID in the Id field of the Get attachments action.
-
Click on Add an action, search and add the action Apply to each.
-
In the Apply to each action where we have Select an output from previous steps go to your Dynamic content, search and select body (this is coming from the Get attachments action) this is shown in figure 16 and 17.
Figure 16: The Apply to each action.
Figure 17: Apply to each action with the dynamic content body seleected.
- In the Apply to each action, click on Add an action, search and add the action Get attachment content. In the action, Get attachment content, select your SharePoint Site and SharePoint list (here we are getting the content of the attachment from SharePoint list A).
Figure 18: The action, Get attachment content with the SharePoint site and list selected.
- In the Get attachment content action, on Id
Figure 19: The Get attacment content action with the dynamic contents ID and Id selected.
- In the Apply to each action, click on Add an action, search and add the action Create file (this is SharePoint action). In the Site Address select your SharePoint site. This is will save the attachments gotten in SharePoint list A.
Figure 20: The action, Create file with the SharePoint site selected.
- In the Create file action, on Folder path; click on the folder icon and then select your Document library. Here I will be selecting the folder Customers Complaint Database.
Figure 21: Create item action; red rectangle showing a folder icon in the folder path of the Create item action and a red rectangle showing the Document library needed.
- In the Create file action, on the File Name field go to the Dynamic content and select DisplayName (this is coming from the action, Get attachments) the result is shown in figure 22. In the File Content field, go to the Dynamic content and select Attachment Content (this is coming from the action, Get attachment content).
Figure 22:Create file action action with the dynamic content for file name and file content selected.
- Inside the Apply to each action, click on Add an action search and add the action Create sharing link for a file or folder (this is coming from the SharePoint action). Here we will be getting our SharePoint Document library. In the Site Address, select your SharePoint site, in the Library Name, select your SharePoint Document Library (For me this is Customers Complaint Database).
Figure 23: The action, Create sharing link for a file or folder with the SharePoint site and document library selected.
- In the Create sharing link for a file or folder, on Item Id; go to the Dynamic content, search and add the dynamic content ItemId. On Link Type click on the drop-down and select View and edit. On Link Scope click on the drop-down icon and select People in your organization.
Figure 24: The Create sharing link for a file or folder action.
- Inside the Apply to each action, click on Add an action, search and add the action Compose.
- In the Compose action, copy and paste the HTML hyperlink below.
<a href ="Link">Name</a><br>
Figure 26: The HTML hyperlink inside the Compose action.
- In the Compose action, where we have Link remove it and go to Dynamic content, search and add the dynamic content Sharing Link (this is coming from the action create sharing link for a file or folder). Next, in the HTML hyperlink, remove the Name text and add the dynamic content Display Name (this is coming from the action, Get attachments).
Figure 27: The Compose action shows the hyperlink with the dynamic contents selected.
- After the Compose action, inside the Apply to each action click on Add an action, search and add the action Append to string variable. Append to string variable; In the Name field, click on the drop-down icon and select Attachment (this is a variable coming from Initialize variable). In Value, go to dynamic content and select the output coming the Compose action, this is shown in figure 28.
Figure 28: Append to String variable action.
- Here, we will be storing the items retrieved from the Customer Complaint SharePoint list (SharePoint list A) into the Customer Support Database (SharePoint list B). In the Apply to each action, click on Add an action, search and add the action Create item (this is an action from SharePoint).
Figure 29: The Create item action with the SharePoint site and list selected.
- Now, let's add the data from the columns we wish to save from the Customer Complaint (SharePoint list A) to the Customer Support Database (SharePoint list B). Create item action; in the 'AccountNumber' field, from the dynamic content, search and select the 'AccountNumber' dynamic content originating from the trigger when an item is created, repeat the same method of others excluding a choice column. For a choice column, click on the drop-down icon select custom value, go to the dynamic content, search and add your choice column value.
Figure 30: Create item action with all the required columns selected.
- Create Item action; In the Attachment link field go to the dynamic content and select the variable "Attachments" this is coming from the Append to string variable. Figure 31: Create item action
FIgure 32: The create item action, with the variable selected from the Dynamic content.
Now go ahead and save and test the flow.
Figure 33: The Apply to each action with all the actions added inside it.
Thank you for reading!