Here’s how to upload files from Power Apps to SharePoint Online (SPO) document libraries.
Prerequisites
First, create a document library in SharePoint Online where files will be uploaded:
data:image/s3,"s3://crabby-images/0fe39/0fe39517b53ea2aed4e7785ea7093ba295ff7f87" alt=""
data:image/s3,"s3://crabby-images/0fe39/0fe39517b53ea2aed4e7785ea7093ba295ff7f87" alt=""
Then, create a SharePoint list.
Note: This is required for using the attachment control.
data:image/s3,"s3://crabby-images/32b15/32b15e96c2a418830f5021223ab8f0abe43bfc3f" alt=""
Note: This is required for using the attachment control.
data:image/s3,"s3://crabby-images/32b15/32b15e96c2a418830f5021223ab8f0abe43bfc3f" alt=""
With these steps completed, we’re ready to proceed.
Creating the Power Automate Flow
First, let’s create a Power Automate flow that will be triggered from Power Apps to handle file uploads.
Create a flow with Power Apps (V2) trigger:
data:image/s3,"s3://crabby-images/50c05/50c05f9ed190e88b0d06995e0949339b4e6d0745" alt=""
data:image/s3,"s3://crabby-images/50c05/50c05f9ed190e88b0d06995e0949339b4e6d0745" alt=""
Add a file type parameter:
data:image/s3,"s3://crabby-images/73646/73646033580710ca51b43e444c8150694184f1a4" alt=""
data:image/s3,"s3://crabby-images/a89f7/a89f7784929dfdf51963909df76bb21aab15d342" alt=""
data:image/s3,"s3://crabby-images/73646/73646033580710ca51b43e444c8150694184f1a4" alt=""
data:image/s3,"s3://crabby-images/a89f7/a89f7784929dfdf51963909df76bb21aab15d342" alt=""
Next, add the SharePoint “Create file” action, select the document library and site we created earlier, and set the [File name] to “triggerBody()[‘parameter_name’][‘name’]”:
data:image/s3,"s3://crabby-images/2c6ba/2c6ba801a0f8285a130699deb643db286e5c18ca" alt=""
data:image/s3,"s3://crabby-images/2c6ba/2c6ba801a0f8285a130699deb643db286e5c18ca" alt=""
For the [File Content], input the parameter itself (specifically, the contentsByte):
data:image/s3,"s3://crabby-images/5e1b7/5e1b776868e411f2015e498417090dcf704655b5" alt=""
data:image/s3,"s3://crabby-images/5e1b7/5e1b776868e411f2015e498417090dcf704655b5" alt=""
And with that, the Power Automate flow configuration is complete!
data:image/s3,"s3://crabby-images/a1e7a/a1e7a444e4c24def1244d8951269d31b1f2756b3" alt=""
data:image/s3,"s3://crabby-images/a1e7a/a1e7a444e4c24def1244d8951269d31b1f2756b3" alt=""
Creating the Power Apps Application
Now, let’s create the Power Apps application.
Create a new canvas app and add the SharePoint list we created in the prerequisites:
data:image/s3,"s3://crabby-images/6390d/6390d587cf0e1c180736072430f5d59c06cf834b" alt=""
data:image/s3,"s3://crabby-images/6390d/6390d587cf0e1c180736072430f5d59c06cf834b" alt=""
Add an [Edit form] to the screen:
data:image/s3,"s3://crabby-images/0d433/0d433746d99a9c291abb1d88f90fd37e7e420648" alt=""
data:image/s3,"s3://crabby-images/0d433/0d433746d99a9c291abb1d88f90fd37e7e420648" alt=""
Set the SharePoint list as the data source, which will create an attachment DataCard. Cut the DataCardValue from within it:
data:image/s3,"s3://crabby-images/d1c20/d1c20ee165496c50f35ca3b29e55ffc792815e88" alt=""
data:image/s3,"s3://crabby-images/d1c20/d1c20ee165496c50f35ca3b29e55ffc792815e88" alt=""
Paste the cut DataCardValue onto any screen and resolve the errors to complete the setup.
Note: For properties showing errors like X and Y, set any arbitrary values, and set the Items property to “blank”
data:image/s3,"s3://crabby-images/dafc3/dafc38e5af9ebf8ef3fbdc908655f43a47e5a8c2" alt=""
Note: For properties showing errors like X and Y, set any arbitrary values, and set the Items property to “blank”
data:image/s3,"s3://crabby-images/dafc3/dafc38e5af9ebf8ef3fbdc908655f43a47e5a8c2" alt=""
And with that, the UI is complete!
Calling Power Automate from Power Apps
Add the Power Automate flow we created earlier using [Add flow]:
data:image/s3,"s3://crabby-images/6b615/6b615374b59040c620249d0520bf0b2a7c594203" alt=""
data:image/s3,"s3://crabby-images/6b615/6b615374b59040c620249d0520bf0b2a7c594203" alt=""
Set MaxAttachments to 1 to limit the number of uploadable files to one.
Note: We’ll discuss handling multiple file uploads later.
data:image/s3,"s3://crabby-images/abce4/abce47437d01d652047096f0c0b7e4f4d50ee8e0" alt=""
Note: We’ll discuss handling multiple file uploads later.
data:image/s3,"s3://crabby-images/abce4/abce47437d01d652047096f0c0b7e4f4d50ee8e0" alt=""
Finally, add an upload button and enter the following formula in OnSelect to complete the setup:
data:image/s3,"s3://crabby-images/f5ddd/f5dddfec54246cf0083f8f133ae02d39a9a58ee8" alt=""
FlowName.Run({ FlowParameterName: { contentBytes:First(AttachmentControlName.Attachments).Value, name:First(AttachmentControlName.Attachments).Name } });
Testing the Application
Run the app, attach any file, and press the button:
data:image/s3,"s3://crabby-images/7e6ea/7e6ea2cec599eae55acf173306c730e7e4f87633" alt=""
data:image/s3,"s3://crabby-images/7e6ea/7e6ea2cec599eae55acf173306c730e7e4f87633" alt=""
Power Automate will execute:
data:image/s3,"s3://crabby-images/d3b1c/d3b1cd5871ac38c9571b8ef1b6f54842e131293c" alt=""
data:image/s3,"s3://crabby-images/d3b1c/d3b1cd5871ac38c9571b8ef1b6f54842e131293c" alt=""
And the file will be saved to the document library:
data:image/s3,"s3://crabby-images/183f6/183f6e561d74e8d932d1c3846faa7dce3dd564d5" alt=""
data:image/s3,"s3://crabby-images/183f6/183f6e561d74e8d932d1c3846faa7dce3dd564d5" alt=""
Uploading Multiple Files
To enable multiple file uploads, change the MaxAttachments to your desired number of files:
data:image/s3,"s3://crabby-images/3c3e4/3c3e4169d989f5b835469b47a016630fe96ba7f0" alt=""
data:image/s3,"s3://crabby-images/3c3e4/3c3e4169d989f5b835469b47a016630fe96ba7f0" alt=""
Then modify the button’s formula as follows:
data:image/s3,"s3://crabby-images/3d96c/3d96ca3e593b83a7c70b1f3e2e69c08fc6df03c8" alt=""
ForAll(AttachmentControlName.Attachments As attachment, FlowName.Run({ FlowParameterName: { contentBytes:attachment.Value, name:attachment.Name } }) );
When you attach multiple files and press the upload button:
data:image/s3,"s3://crabby-images/39214/392144fa533c9b251d258aebd07dd19045e3b315" alt=""
data:image/s3,"s3://crabby-images/39214/392144fa533c9b251d258aebd07dd19045e3b315" alt=""
Multiple files will be uploaded.
Note: Files with the same name will be overwritten.
data:image/s3,"s3://crabby-images/9d23e/9d23e66d7b915e5a6791e4cd1da3a99fc114e0ef" alt=""
Note: Files with the same name will be overwritten.
data:image/s3,"s3://crabby-images/9d23e/9d23e66d7b915e5a6791e4cd1da3a99fc114e0ef" alt=""
While it’s possible to upload files by getting dataUri using an image control, I personally prefer this method as it provides a more concise implementation.
コメント