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!
Did You Enjoy This Article? 😺
Subscribe to get new Power Apps articles sent to your inbox each week for FREE
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.
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?
Valerie,
This came out about a month ago but it was a stealth release (no documentation). I am still trying to figure out how to successfully output a file data type from Flow in the V2 trigger and also just the email data type in general.
Shane and Ramiro’s JSON method was an awesome find. But I’m glad we finally have something straightforward now.
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!
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,
Very good question! When the flow input is required this is the correct syntax:
UploadFileToDocumentLibrary.Run(
{
contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
name: First(att_SubmitContract_AttachFile.Attachments).Name
}
);
But when the flow input is optional this is the proper syntax:
UploadFileToDocumentLibrary.Run(
{
file: {
contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
name: First(att_SubmitContract_AttachFile.Attachments).Name
}
}
);
My screenshot has caused some confusion so I will go ahead and correct it. The tutorial uses required flow inputs only so my code will be OK.
Thank you for the detailed and lovely feedback korune 🙂
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.
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!
David,
Can you please share a screenshot of the error message you are receiving?
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
John,
I can see you have built an Edit Form from a SharePoint list. What I think you intend to do is attach a file to the SharePoint list. If this is true, my tutorial does not apply to your scenario. All you have to do is submit the form using the SUBMITFORM function and it will attach the file. No special tricks are needed.
My tutorial is for SharePoint document libraries only.
Any ideas/recommendations on using your solution for an Edit Form in a SharePoint list? In the “classic” version, users with add-only (no edit) rights could add attachments using a simple SubmitForm. In the “modern” version, users with add only rights cannot add attachments. Users need edit rights, but in many cases, users should only be able to add list items (dozens or hundreds of articles on this). Any thoughts? Thanks!
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!
Thank you Gilmour!!
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,
Did you set the trigger input field to required?
Thanks, Matthew for your response. I have resolved the issue. Thanks, once again for the great article.
Asheer,
Was the problem fixed by what I described or something different? If something different, please let me know what the issue is.
Hi Asheer, I get the same error message. The trigger input field is set to required. How did you solve the issue?
Vivi,
Try toggling the input field’s required setting. You might think its in the correct position when it is fact not.
Hi Mathew,
I know this is an old post, but I seem to be having the same error with the flow. (I’m unsure where “the input field required setting” is located)
Any help would be much appreciated!
InvalidTemplate. 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. Please see https://aka.ms/logicexpressions for usage details.’.
I think i found the required field and it will still not work. Any ideas?
Forget to attach…
John,
Click on the Make Required option in that menu to get it to work.
for others that have not caught this. This took me ages to figure out. The “Make the Field Required” checkbox is not really a checkbox. It is a toggle. I kept look at the checkbox expecting the checkmark to disappear and didn’t read the words. Clicking on it toggles between required/optional and both have a checkmark. (A great example of poor UI to avoid in application design!)
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.
ThunkJunkie,
Yes, I would like to see it get easier too. Workarounds get the job done but they require research to learn. It would be neat if it were possible by only using the PATCH function.
Thank you for taking the time to share your method.
Wow this is another amazing blog! This inspires to do some great PowerApps/Flow stuff. Many thanks Matthew!
Andre,
I’m glad you liked it. I wonder what you are going to build now?
Andre,
You’re welcome. I’m glad you enjoyed the article 🙂
excellent post. can you tell how to upload multiple documents from the attachment control to sp library ?
Monica,
Great suggestion! I have added a new section to the tutorial showing how to upload multiple files at once.
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?
MM,
Do you have a screenshot of the syntax error message you are receiving?
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,
You could send everything in the same flow by allowing multiple file type inputs in the trigger and passing them all at once.
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
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
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,
Yes that makes sense and it should work. Let me know if it doesn’t.
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}}
Gregory,
The reason your code is different is because you have made your flow parameters optional. Since mine are required I did not have to specify the parameter name. There is a note am bout using required fields directly below the code block.
I’m glad you are having so much fun with this idea!
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.
Tony,
Can you please share the error message you are receiving?
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.’.”
Mike,
Did you remember to set all of your flow trigger inputs to required? This is the likely cause of your app’s issue.
Hello,
I am having the same issue and I did ensure the inputs are required.
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.’.
did you managed to get it working now bro because i am having the same issue
Had the same issue. I resolved it by using a compose statement above the ‘create file’ section and entered it using the function builder in dynamic content. Use the compose output in the ‘create file’ section instead.
Can you share what you placed in your Compose statement? Screenshots would be great if its not to much trouble. Thanks!
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?
Mykie,
Did you remember to change all of your flow trigger inputs to required? I think this could be the cause of the problem.
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
Veronica,
Here’s a couple suggestions:
1. https://powerusers.microsoft.com/t5/Building-Power-Apps/Possible-to-clear-attachments-when-editing-a-form/td-p/648621
2. https://powerusers.microsoft.com/t5/Building-Power-Apps/How-can-we-reset-the-attachment-field/td-p/136245
In your example you have not placed the attachment control in a form. Therefore your suggestions are not usable to reset the attachment control. How do you reset it if the attachment control is not placed in a form?
His suggestions were usable —
In the example below, the file attachment control is named ‘att_File’.
Clicking the button will clear the files from the ‘att_File’ control
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.
Mike,
For checkboxes the flow trigger could be updated to accept a ‘yes/no’ type value. For comboboxes, its more complicated. iIfyou are using a complex data type such as a Choice, Person, or LookUp you would have to modify the flow and app to accept them. One method is to pass only the unique identifier from a complex column as a text field and get the full object from inside flow.
RE: SharePoint Choice field – PA Combo Box – Flow -> can anyone expand on this? In my solution, I’m uploading business related receipts. I’d like to use my pre-built SP column data to tag the receipt as a ‘Meal’, ‘Entertainment’, ‘office expense’, etc. TIA
Thanks Matthew,
Is really useful
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
Andrew,
Thanks for the compliment, I’m glad you got it working 🙂
To append a date and time stamp to the document name you can use this code:
{
contentBytes: First(att_SubmitContract_AttachFile.Attachments).Value,
name: First(att_SubmitContract_AttachFile.Attachments).Name&” “&Text(Now(), “yyyy-mm-dd hh:mm:ss”)
}
For the managed metadata question, I’m terribly sorry, but I’m just not sure. I have not used managed metadata while building apps 🙁
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
Andy,
Have you remembered to set all of the flow trigger inputs to required? If the RUN formula expects only 1 argument its likely to be because your flow inputs are optional.
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.
Bojan,
All of your flow inputs are set to optional. My tutorial requires all flow inputs to be required. Please re-read the section of my article titled “Add Metadata To A SharePoint Document Library” and look at the 2nd paragraph.
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,
Did you delete the flow from your app and add it back after making the changes. Sometimes Power Apps does not recognize any changes until we do this.
I didn’t delete the flow from the app. Will try this tonight. Thanks.
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.
And here is the screenshot of the flow.
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.’.”
Mike,
Please set all of the trigger inputs to required and then this message will likely go away.
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!
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”].
Phil,
Power Automate connections are a little quirky sometimes. Sorry to hear you ran in to some of the eccentricities.
Hi Phil,
I have the same problem… could you explain how to solve? Thanks!
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.
Devan Roberson,
Yes, the code will work with dropdowns/comboboxes so long as the output is text. However, if you are using a complex data type such as a Choice, Person, or LookUp you would have to modify the flow and app to accept them. One method is to pass only the unique identifier from a complex column as a text field and get the full object from inside flow.
Just sent another comment/response and then found this gem related to my comment.
So, in the Library, I am performing a Lookup Value from another SP List (call them ABC IDs that have all sorts of other linked metadata). The Power App shows that Lookup List and allows the user to select an ABC ID to be passed and stored in the Library with the attachment File.
Passing a Text value does not appear to work. Everything else is successfully inserting into the library sans the Lookup value selected by the User.
Could you elaborate or point to a link that speaks more to the “Full object from inside flow” you referenced? I have not quite comprehended how to pass that user selected Lookup value to the Library with the file.
Again, great topic and tutorial!
Matthew, this guide is a great start and has helped me much in my endeavor. However I have the same question as Devon, and was hoping you could elaborate more on this flow and how to better set it up for Dropdowns, as I’m running in to a similar issue or there is some syntax missing. I have included my code, and a screenshot of the form that is based of Columns in the Library. Any help is greatly apprciated
OQEUpload.Run(
{
contentBytes: First(OQEAttachmentControl1.Attachments).Value,
name: First(OQEAttachmentControl1.Attachments).Name
},
DataCardValue64.Selected.Value,
DataCardValue65.Selected.Value,
DataCardValue66.Selected.Value,
DataCardValue67.Selected.Value,
DataCardValue68.Selected.Value,
DataCardValue69.Selected.Value,
DataCardValue24.Selected.Value,
DataCardValue61.Selected.Value,
DataCardValue64.Selected.Value,
DataCardValue62.Selected.Value
);
Could you please elaborate on how you would accomplish this action this? I’m attempting to do this and coming up empty, In my situation I have a SP Document Library with a Lookup Column called “Member Name”, that looks at a SP list and get a text filed called “Recorded Name”. In my Flow, i have a Input called “Member Name” but when I go to the file properties step that Input is not available for that section in the Update File Properties step, it wont show up.
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!
Charles S,
Can you isolate which argument is invalid? I’ve revised the SelectedDate.SelectedDate code to only a single SelectedDate but other than that the code appears to be working for me. Maybe the order of the arguments needs to be different-based on how your setup the flow trigger?
Hi Matthew, I believe I have the same issue as Charles. I can get the upload file to work with the flow, but as soon as I bring in the ‘txt_SubmitContract …’ lines it stops working. I’m also wondering if there is a way to define the text inputs to match with the flow? Or does the flow automatically populate based on the order of input?
Side note – for my power app, the metadata inputs are drop-downs and numbers. How can I bring these in to the button function?
Thanks in advance, Melissa
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!
Angel,
Hmmm, I’m not sure I understand this question. Is there a screenshot you can share?
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.
David,
Thanks for sending this message and providing your solution. I’m thinking many of the others are having the same issue. I’ve made the directions bold in the tutorial so hopefully everyone sees that we are using a required field in the flow.
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.