Power Apps Easiest Way To Upload Files To A SharePoint Document Library

Power Apps Easiest Way To Upload Files To A SharePoint Document Library

Uploading files to SharePoint document library from Power Apps just got easier! Attaching files in Power Apps and saving to them SharePoint is a common requirement for many apps so its an important skill to learn. To do this we will use the new Power Apps (V2) trigger in Power Automate which includes the file data type as an input It is no longer necessary to perform a complicated series of steps to transform a file to binary using the JSON function and then back to Base64 (not exactly low-code).

In this article I will show you the easiest way to upload files to a SharePoint document library in Power Apps and add metadata (i.e. tags) to the file.

Table of Contents:
Introduction: The Submit A Contract App
Setup The SharePoint Document Library
Insert An Attachments Field
Make A Flow To Upload Documents To A SharePoint Library
Connect The 'Upload To SharePoint' Flow In Power Apps
Upload Multiple Files To A SharePoint Document Library
Add Metadata To A SharePoint Document Library
Display Recently Uploaded Files




Introduction: The Submit A Contract App

The Submit A Contract app is used by salespeople at a bakery to upload contract files to a SharePoint document library. Once a contract is signed the salesperson attaches the file, adds some metadata (customer name, contract date and customer type) to help keep the contracts organized and presses the upload button to submit the file



Setup The SharePoint Document Library

Add a new SharePoint document library called Contracts with the following columns and types:

  • Name (single-line text)
  • CustomerName (single-line text)
  • SoldDate (Date only)
  • Industry (single-line text)

The document library will look like this once we upload some files later in the tutorial.




Insert An Attachments Field

In the Submit A Contract app a salesperson needs to add a file to an attachments field and upload it to SharePoint. Open Power Apps and Create a new app from blank. Then insert a few labels and icons to make it look like the screenshot below.



The attachments field cannot be inserted from the menu so we must use a workaround. Go to the data tab on the left menu and add any existing SharePoint list from your SharePoint site. Do not add the Contracts SharePoint document library we created earlier. We cannot use it to generate an attachments field.



Create a new Edit Form with your SharePoint list as the data source. The attachments control should automatically appear when we create the form. If it does not, you can add the attachments field using Edit fields on the right-side menu.



Cut the attachments control and paste it outside the form. Delete the form.



Use the following properties in the attachments control:

Items: Blank()
DisplayMode: DisplayMode.Edit
MaxAttachments: 1



Our app now has an attachments field we can use to upload the contract documents. We can now delete connection to the SharePoint list. It is no longer needed.




Make A Flow To Upload Documents To A SharePoint Library

Documents cannot be uploaded to a SharePoint document library directly from Power Apps. We will need to create a Power Automate flow to do it instead. Open the Power Automate action from the top menu and select Create a new flow.



Choose the Power Apps button template.



Name the flow UploadFileToDocument library and click Save.



We want to use the PowerApps (V2) trigger because it supports files as an input type whereas the PowerApps trigger does not. Delete the PowerApps trigger and add PowerApps(V2) in its place.



Select the File input type. Name the input File Content. Make File Content a required input.



Add a SharePoint action to the flow: Create File. Use your SharePoint site address and document library folder path as inputs. The File Content field should reference the file found in our flow trigger.



File Name requires a flow expression. Open the flow expression editor then copy + paste this code into the File Name field.

triggerBody()['file']['name']



We are now done creating the flow to upload a document.




Connect The ‘Upload To SharePoint’ Flow In Power Apps

Go back to PowerApps and add a button. Select the OnSelect property and click on the UploadFileToDocumentLibrary field in the Power Automate menu.



The flow will appear as a connection in the data tab.



Remove any code from the Upload button’s OnSelect property and replace it with this code. A file must be passed as an object to Power Automate. The contentBytes field holds a reference to the attachment file and name stores the filename and extension.

UploadFileToDocumentLibrary.Run(
     {
         contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
         name: First(att_SubmitContract_AttachFile.Attachments).Name
     }
 );


Note: if you are receiving an error when passing the file to the flow make sure you have set the flow input to be a required field.

We’re done creating the ‘upload a document to a SharePoint library’ functionality. Test your app to make sure its working.



The contract document should appear in your SharePoint site as shown below.




Upload Multiple Files To A SharePoint Document Library (Optional)

If we wanted to include the ability to upload multiple files at the same time we could change the OnSelect property of the upload button to loop through each attachment and run the flow once per file. We will also need to increase the MaxAttachments property of the attachment control from 1 to another value.

ForAll(
    att_DocLib_SubmitContract.Attachments As Document,
    UploadFileToDocumentLibrary.Run(
        {
            contentBytes: Document.Value,
            name: Document.Name
        }
    )
);



Since this is an optional step, the rest of this article will assume you have used the single-file upload method.




Add Metadata To A SharePoint Document Library

The salesperson must also include additional data about the contract to keep the contracts files organized. The technical term for this is metadata: “data-about-data”. But most folks simply call it tagging documents.

Add a few text inputs (Customer Name, Industry) and a date picker (Contract Date) as shown below to capture the metadata.



We must update the Upload Document To A SharePoint Library flow to insert the metadata from Power Apps. Modify the Power Apps (V2) trigger action to add 3 new inputs as shown below. They should all be required inputs.


Then add another action at the bottom of the flow: SharePoint – Update file properties



Now we are done updating the Flow. Go back to Power Apps…



…and update the OnSelect property of the upload button with this additional code to pass the new parameters. Notice that the parameter names do not match the names we defined in flow. They are generic names based on the data type.

UploadFileToDocumentLibrary.Run(
     {
         contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
         name: First(att_SubmitContract_AttachFile.Attachments).Name
     },
     txt_SubmitContract_CustName.Text,
     Text(
         dte_SubmitContract_ContractDate.SelectedDate,
         "[$-en-US]yyyy-mm-dd"
     ),
     txt_SubmitContract_ClientType.Text
 );



We can now include metadata with the document at the time of upload to SharePoint. Give this new functionality a test and check SharePoint to make sure the data was successfully written.




Display Recently Uploaded Files

A salesperson might want to see a list of the most recently uploaded files. To add this feature, connect the app to the Contract document library in SharePoint.



Then add a gallery to the Submit A Contract app that looks like the screenshot below.



Use this code in the Items property of the the gallery to show uploads from newest-to-oldest.

Sort('Contracts', Modified, Descending)


Put this code in the Text property of the name label…

ThisItem.Name



…and this code in the Text property of the date modified label.

ThisItem.Modified



That’s it, we’re done!





Questions?

If you have any questions or feedback about Power Apps Easiest Way To Upload Files To A SharePoint Document Library please leave a message in the comments section below. You can post using your email address and are not required to create an account to join the discussion.

Matthew Devaney

Subscribe
Notify of
guest
211 Comments
Oldest
Newest
Inline Feedbacks
View all comments
Valerie Schaffer
Valerie Schaffer
1 year ago

This is awesome and a lot easier to configure than @ShanesCows workaround with v1, although that was a feat of wonderfulness, too! When did v2 come out, anyway?

Erol
Erol
1 year ago

Hey Matthew! Do you have a Book / PDF collection of most to all of your Articles and Posts? If so, I am ready to buy! I think you have shared and published absolutely excellent well written Articles that are among the best. Each Article is filled with practical information and examples to learn from. Your work is amazing!

korune
korune
1 year ago

Thanks for the great post!

I was just curious about one point…You describe the Content Type to be passed to Power Automate as follows, but doesn’t this cause the flow to fail because the Outputs in Power Automate do not include the body?

UploadFileToDocumentLibrary.Run(
{
contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
name: First(att_SubmitContract_AttachFile.Attachments).Name
}
);

I figured that I need to set up the equation correctly like in the screenshot.

UploadFileToDocumentLibrary.Run(
{
file: {
contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
name: First(att_SubmitContract_AttachFile.Attachments).Name
}
}
);

korune
korune
1 year ago

I see! I understand now.

So the way to pass from Power Apps is different when input is required or optional in Power Automate.

Thank you for your detailed explanation.

David Naughton
David Naughton
8 months ago

Hi Matthew, as I’m doing this on my own PowerApp, I presume that I replace the ‘att_SubmitContract_AttachFile’ with the name of my PowerApp?
This my code:

UploadFileToDocumentLibrary.Run(
{
contentBytes: First(att_Year2LearningLead-ImpactLog_AttachFile.Attachments).Value,
name: First(att_Year2LearningLead-ImpactLog_AttachFile.Attachments).Name
}
);

However, I keep getting error messages!



Last edited 8 months ago by David Naughton
John
John
8 months ago

Hi Matthew,

Thank you for your tutorial!

I have the same question as David; from the explanation it’s clear that contentBytes: refers the button’s “on select” to a specific attached file and the name: gives that file a name.

However, it’s not clear how to configure these for custom applications and the code block you’ve provided doesn’t work outside the parameters you’ve setup on your app.

That said, how can we configure this code block to apply to the file dropped in the attachments box?

If this mess of arrows makes any sense

Capture.PNG
Gilmour
Gilmour
4 months ago
Reply to  David Naughton

Hi David. I also thought that att_SubmitContract_AttachFile is the name of the app when, in fact, it’s actually the name of the attachment control (you can also see it in one or more of Matthew’s screenshots in the blog). After many failed attempts, it dawned on me, and everything worked out as expected!

Asheer
Asheer
3 months ago

Hi Matthew,

First of all Great Work!!! I have tried it but am getting the below error. Please assit

Unable to process template language expressions in action ‘Create_file’ inputs at line ‘0’ and column ‘0’: ‘The template language expression ‘triggerBody()[‘File’][‘Name’]’ cannot be evaluated because property ‘File’ cannot be selected. 

Asheer
Asheer
3 months ago

Thanks, Matthew for your response. I have resolved the issue. Thanks, once again for the great article.

Thunkjunkie
Thunkjunkie
1 year ago

The v2 trigger is cool but i can’t help thinking this is something that should be much more straightforward to achieve (uploading files to doc library via power app). FWIW, my ‘go to’ is to create a list with the same site columns as my doc library and just use that in my power app to collect the data and attach a file. Then have a Flow that runs on ‘New list item created’ that moves the attachment to the doc library and updates the doc library metadata with the list item metadata. I usually then delete the list item.

André van Onselen
André van Onselen
1 year ago

Wow this is another amazing blog! This inspires to do some great PowerApps/Flow stuff. Many thanks Matthew!

Monica Jagani
Monica Jagani
1 year ago

excellent post. can you tell how to upload multiple documents from the attachment control to sp library ?

M M
M M
1 year ago

Matthew,

This has been extremely helpful, many thanks!

However, I remain struggling with the combination of uploading multiple files while also setting the metadata. In my case, the metadata is identical for all files uploaded, so it should be easy. Just can’t get my syntax right… 🙂

Can you maybe also share an example of what to put in the OnSelect property in this scenario?

Gregory Lee
1 year ago

Matthew, thanks! Your solution to the multiple document option was to re-run the flow for each document. is it possible to run the flow only once but get multiple attachments to go through? I have a complex flow that generates an invitation email and then an Adobe Sign contract. The attachments generated by the app would need to go through together to the one flow.

Gregory Lee
1 year ago

I did think of that, although obviously it does add a fair whack of complexity. Pity you can’t do an apply to each sort of thing, but there it is

Chase Basham
Chase Basham
2 months ago
Reply to  Gregory Lee

Matthew and Gregory,

I hope you all are doing well today. I currently am developing an app that starts an approval process when my form on PowerApps is submitted.

The issue I am running into currently is the re-running of the flow for each document. It works perfectly fine until I move over to my Power Automate flow.

My Automate flow is written to pull the files stored in a specified folder and include them as attachments in the email sent to my approvers. However, when using your workaround in PowerApps, it causes the Automate flow to send as many emails as there are documents.

So five documents means five individual emails to my requestors.

Please let me know if you all can help in any sort of way.

Best

Gregory Lee
1 year ago

Matthew, one more thing now that I’m testing your solution. So far as I can tell, First(<name of control>.Attachments).Value returns the blobmanager url only. Am I missing something?

Gregory Lee
1 year ago

So, what I didn’t realise is that the file input in the trigger can process the blobmanager URL as a file, which is absolutely awesome. Just a note though: your code above did not work for me. I had to do:

{file:{name:Last(AttachFile.Attachments).Name,contentBytes:Last(AttachFile.Attachments).Value}}

Tony Adrian
Tony Adrian
1 year ago

So when I enter the triggerBody()[‘file’][‘name’] for the file name PowerAutomate throws out an error – I have deleted and rebuilt the flow several times and still an error – is there something that I am missing? I entered this in the expressions for the File Name.

Mike
Mike
1 year ago

I am getting the same thing:
“Unable to process template language expressions in action ‘Create_file’ inputs at line ‘1’ and column ‘11905’: ‘The template language expression ‘triggerBody()[‘file’][‘name’]’ cannot be evaluated because property ‘file’ cannot be selected. Please see https://aka.ms/logicexpressions for usage details.’.”

Angelina
Angelina
3 months ago

Hello,

I am having the same issue and I did ensure the inputs are required.

David
David
1 year ago

Here is what my sample app is returning with a similar error

InvalidTemplate. Unable to process template language expressions in action ‘Create_file’ inputs at line ‘1’ and column ‘11834’: ‘The template language expression ‘triggerBody()[‘file’][‘name’]’ cannot be evaluated because property ‘file’ cannot be selected. Please see https://aka.ms/logicexpressions for usage details.’.

4edu vid
4edu vid
6 months ago
Reply to  David

did you managed to get it working now bro because i am having the same issue

Mykie
Mykie
1 year ago

Hi,

thanks for your post, I tried to use upload multiple documents, but flow doesn’t started, If I use ForAll function.
If I upload only one file, I get an error:
Unable to process template language expressions in action ‘Create_file’ inputs at line ‘1’ and column ‘12241’: ‘The template language expression ‘triggerBody()[‘file’][‘name’]’ cannot be evaluated because property ‘name’ doesn’t exist, available properties are ”. Please see https://aka.ms/logicexpressions for usage details.’.

Have you any idea, where is the mistake?

Veronica
Veronica
1 year ago

Hello, do you know maybe if there’s a way to clear attachments control after upload? All methods I tried to use are invalid, because AttachmentControl.Attachment is not a collection. I would greatly appreciate your help

Mike
Mike
1 year ago

this is an incredibly helpful post. When adding the meta data, I’m wondering how to do that for combo boxes and check boxes? I can’t seem get these to work with flow.

Leon
Leon
1 year ago

Thanks Matthew,

Is really useful

Andrew C
Andrew C
1 year ago

Thanks very much for a super useful post – even a total newbie to PowerApps like me was able, with a bit of trial and error, to get the upload working.

I’d also like to be able to add metadata at the upload stage but going one step further I’d like it to be managed metadata (i.e. matching terms in the termstore) – is it possible to get a PowerApp to query SharePoint for allowed terms or is that asking too much of it?!

Another thing I’d like to do, which I think should be possible, is to append a date & timestamp to the filename as it’s uploaded as otherwise we will be at risk of lots of files going into the library with the same name and then (1), (2), etc. appended by SharePoint.

Thanks!

Andrew

Andy
Andy
1 year ago

Hello Matthew, thank you for a great solution. I have been able to apply this successfully to simple file attachment and upload. When adding meta data I am receiving an error on the submit button once I adjust the code. Any suggestions would be appreciated.

Function ‘Text’ has invalid arguments. Invalid number of arguments: received 4, expected 1

Bojan
Bojan
6 months ago

Hello Matthew,
I have the same issue and I was many times checked and all inputs are set to be required and the same error is here. Take a look at the screenshot.

Screenshot_2.jpg
Bojan
Bojan
6 months ago

Thanks for the answer Matthew.
But I already checked and clicked on 3 dots on the right for each input field and clicked on Make this field required. I don’t know what else I can do?

Bojan
Bojan
6 months ago

I didn’t delete the flow from the app. Will try this tonight. Thanks.

Bojan
Bojan
6 months ago

Now it’s worked. 2 things I need to modify. First that you told me, to delete the flow from the app and add it again and the second one is the format date. I need to put this in the code line for the date picker “[$-en-US]yyyy-mm-dd”. With any other format, it throws out the error that it is an unsupported format. Thanks again.

Bojan
Bojan
6 months ago

And here is the screenshot of the flow.

Screenshot_3.jpg
Mike
Mike
1 year ago

Power Automate is throwing this error when I enter the triggerBody()[‘file’][‘name’]: Have you seen this before?

“Unable to process template language expressions in action ‘Create_file’ inputs at line ‘1’ and column ‘11905’: ‘The template language expression ‘triggerBody()[‘file’][‘name’]’ cannot be evaluated because property ‘file’ cannot be selected. Please see https://aka.ms/logicexpressions for usage details.’.”

Phil
Phil
7 months ago

Power Automate is also throwing the same error for me but only when accessing via Power App. The flow works when testing direct. I have only one trigger (file input) and it is already set at ‘required’. Is there a working solution to this?

Edit: Sorry, forgot to say thanks! Excellent tutorial!

Last edited 7 months ago by Phil
Phil
Phil
7 months ago

Hi Matthew, I managed to get this sorted. I needed to removed and re-attach the flow to my power app before this started to work. Also, simply selecting ‘make the field required’ on the the flow trigger did not work for me. I had to ‘peek code’ and enter it manually within “required”: [ “file”].

Devon Roberson
Devon Roberson
1 year ago

Does this function work with drop-downs?

I’ve attempted using it with my drop-downs for metadata but it gives me an error.

UploadFileToDocumentLibrary.Run(
{
contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
name: First(att_SubmitContract_AttachFile.Attachments).Name
},
txt_SubmitContract_CustName.Text,
Text(
dte_SubmitContract_ContractDate.SelectedDate.SelectedDate,
“[$-en-US]yyyy-mm-dd”
),
txt_SubmitContract_ClientType.Text
);

Maybe my syntax is off, please advise.

UploadFileToDocumentLibrary.Run(
   {
     contentBytes: First(AttachFiles.Attachments).Value,
     name:  First(AttachFiles.Attachments).Name
   },
   Directorate_Dropdown.Selected.Value,
   Unit_Dropdown.Selected.Value,
   RecordSeries_Dropdown.Selected.Value
 );

When I use without the metadata it works perfectly.

Charles S
Charles S
1 year ago

Hello Matthew, thank you for such a clear and detailed rundown. I am not a programmer, and am working this as a side project; however, I keep running into an error with the Update Content addition code:

UploadFileToDocumentLibrary.Run(
   {
     contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
     name: First(att_SubmitContract_AttachFile.Attachments).Name
   },
   txt_SubmitContract_CustName.Text,
   Text(
     dte_SubmitContract_ContractDate.SelectedDate.SelectedDate,
     “[$-en-US]yyyy-mm-dd”
   ),
   txt_SubmitContract_ClientType.Text
 );

With the above coding (from your field above) I get multiple errors (name isn’t valid, invalid use of “.” (x2), ‘Text’ has some invalid arguments, and invalid number of arguments: received 4 arguments, expected 1).

If I change code to the following, I can reduce errors to just the invalid number of arguments, 4 vs 1:

UploadFileToDocumentLibrary.Run(
   {
     contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
     name: First(att_SubmitContract_AttachFile.Attachments).Name
   },
   txt_SubmitContract_CustomerName.Text,
   Text(
     dte_SubmitContract_ContractDate.SelectedDate,DateTimeFormat.LongDate
   ),
   txt_SubmitContract_ClientType.Text
 );

I thank you for any advice you can give – this is an exact solution for our needs, and I am not smart enough on my own to fix it yet. Thank you for looking into it!

Angel
Angel
1 year ago

Hey Matthew,

This is really helpful! However, i am just wondering if there is a way i can change the name of the attachment from the dropdown boxes of other areas in the form so that it doesnt show a string of numbers when uploading from iphone?

Ideally it should show code-area-date.doc if possible.

Thank you so much!

David
David
1 year ago

Just a note for others, when you first create the trigger, select the ellipses next to file content to select “Make Field Required”, it looks like a check box is selected, but it really isn’t required until you click it. It will then switch to look like the image below.


I had to also go and remove the flow in my app and re-add it to get rid of the errors I was getting after making this change.

Iain
Iain
1 month ago

Hi David, thanks for this, ive just updated one of my apps that was using Shane’s way, i had seen the file in the V2 so was wondering how to go about it! Just to add to Davids comment, you can use the Peek Code to check if they are required or not.