This guide explains how to create a pop-up window like a pop-up form that appears when a user clicks a button. This feature is useful for displaying additional information or to include an edit form without navigating away from the current screen.
Let’s be more specific about our goal.
Here’s an example of what we want:
1. Click on the button New Project
data:image/s3,"s3://crabby-images/87a32/87a3221678b5a609d3e68e74b5a97e661d96e511" alt="Click on the button New Project"
2. Here becomes visible the Form
As you can see, when the pop-up appears, the background color turns light gray. That's an additional tip to make this functionality look better!
data:image/s3,"s3://crabby-images/129ea/129eaca05c38e86965d4d974094173e176e5206e" alt="Here becomes visible the Form"
3. You have the opportunity to fill in the fields and click on the Submit button to create a new project
data:image/s3,"s3://crabby-images/51ef7/51ef7170cc7df31c17f58bcf060a76210a795f96" alt="You have the opportunity to fill in the fields and click on the Submit button to create a new project"
4. Otherwise, click on Cancel to close the pop-up form
data:image/s3,"s3://crabby-images/6e541/6e541c46845a931550684dd62aa526a125a677ef" alt=""
Let’s dive into it and explain how we can achieve this functionality.
Step by step guide
Step 1
Add a button to the screen you want to create the pop-up.
i) Click on Insert
data:image/s3,"s3://crabby-images/d246b/d246b13510b3140ae4985054b5ecc59270e2321a" alt="Click on Insert"
ii) Click on Button
data:image/s3,"s3://crabby-images/77d95/77d954637d29ee947d626d1efba3293af9f6001d" alt="Click on Button"
iii) Position the button where you want it to appear on the screen
Set its properties as you prefer, change the size, and the color, and choose a text to call your button. For this example it’s 'New Project'.
data:image/s3,"s3://crabby-images/ebbc5/ebbc5488c653168c8bba4a39daf27e8c210d1ce9" alt="Position the button where you want it to appear on the screen"
Step 2
Define the button’s action.
To make the form visible wherever the button is clicked, we have to set the OnSelect property of the button, the formula:
‘Set(isForm1Visible, true)’
‘isForm1Visible’ is a variable we created to control the visibility of the pop-up
* if you want to create more than 1 pop-up form in your app you have to use different variables to control the visibility. For example isForm1Visible, isForm2Visible, isForm3Visible etc.
i) Click on Property dropdown and go to the OnSelect
data:image/s3,"s3://crabby-images/839ca/839ca002fcf8bafa30d9ab494f60e55283af2fb5" alt="Click on Property dropdown and go to the OnSelect"
ii) Define the formula: Set(isForm1Visible, true)
data:image/s3,"s3://crabby-images/79239/79239cb511d32f0d535adedd40bfb8858028a4b5" alt="Define the formula : Set(isForm1Visible,true)"
Step 3
Add a container that will include the Label ‘Form’ at the top, the fields of the form, and 2 buttons for submit and cancel at the bottom.
Like this:
data:image/s3,"s3://crabby-images/d6231/d6231bb85a1ed3a103cd3afc94bc1c5508b77325" alt=""
i) Click on Insert
data:image/s3,"s3://crabby-images/c9e8e/c9e8e592c5e2705317a2b64e11aea471951ea2a7" alt="Click on Insert"
ii) Click on Container
data:image/s3,"s3://crabby-images/549ca/549ca6a86a65f44bc3418b47fe495d29e68dca71" alt="Click on Container"
iii) Place the container in the middle of the screen
data:image/s3,"s3://crabby-images/f27da/f27dafeb55b3603788a900d50dbbe660d9ab5316" alt="Place the container in the middle of the screen"
Control Container’s visibility
iv) Click on Form_Container
data:image/s3,"s3://crabby-images/2e1c5/2e1c5420e891f3256fd063e2a6ade9ce5b49a68c" alt="Click on Form_Container"
v) Click on Visible Property and set the variable ‘isForm1Visible’
data:image/s3,"s3://crabby-images/f55ac/f55acb616a998d9608b3b6eb5d9c280c8f8db8aa" alt="Click on Visible Property"
iv) Click on Fill Visual background color.
data:image/s3,"s3://crabby-images/b437c/b437ce17333ad2e70fb9de53a6d887b402763ec3" alt="Click on FillVisual background color."
v) Click on the white color
data:image/s3,"s3://crabby-images/dc0f7/dc0f75ae4d786be57b9c0c6ff72bb21326a2bb2e" alt="Click on the white color"
Step 4
Add a label at the top and 2 buttons at the bottom of the container.
i) Click on Form_Container
data:image/s3,"s3://crabby-images/d0d37/d0d37a73008685a03b60f393da8c8e84cc9679c0" alt="Click on Form_Container"
ii) Click on Insert
data:image/s3,"s3://crabby-images/28013/2801352812a771b919010205973dea2908dc0664" alt="Click on Insert"
iii) Click on Button
data:image/s3,"s3://crabby-images/0b9f3/0b9f3cea9bc8ae7dbe9a7db1678525b01fbdcf3e" alt="Click on Button"
iv) Place the button at the bottom of the container and adjust the size, the color, and the display name.
data:image/s3,"s3://crabby-images/d39e1/d39e168b2a6b26000b110987eb8475d435d4d99a" alt="Place the button at the bottom of the container and adjust the size, the color, and the display name"
Do the same for the Submit button as you see
v) Click on Insert
data:image/s3,"s3://crabby-images/28013/2801352812a771b919010205973dea2908dc0664" alt="Click on Insert"
vi) Click on Text label
data:image/s3,"s3://crabby-images/ca9fd/ca9fdcc4a0bbb055911353895cd902b89416de7b" alt="Click on Text label"
Step 5
Add the edit form inside the container.
i) Click on Insert
data:image/s3,"s3://crabby-images/790be/790beee0277b1039ae0b5651ff07f3bce98f30de" alt="Click on Insert"
ii) Click on Edit form
data:image/s3,"s3://crabby-images/5698d/5698d8e09de8fdc14d2117ed02488accc135a9cd" alt="Click on Edit form"
iii) Click on a Database you want to connect your form
data:image/s3,"s3://crabby-images/cdee8/cdee8c6a11c16ce08792b31c401b5c2170c73320" alt="Click on a Database you want to connect your form"
Control form’s visibility
iv) Click on Form1
data:image/s3,"s3://crabby-images/0a921/0a9219f28228baf3a6d3b64692143d9e75499a4d" alt="Click on Form1"
v) Click on Visible Property and set the variable isForm1Visible
data:image/s3,"s3://crabby-images/b8941/b8941bfa7f6c6bb2ba4f950822a25f6fc481fc43" alt="Click on Visible Property"
Step 6
Make the preferable changes to the fields of the form.
i) Click on the dropdown of Columns Property to change the way that fields appear
data:image/s3,"s3://crabby-images/3e3af/3e3af28bc86067c58411cfae391369822d8eb47e" alt="Click on the dropdown of Columns Property to change the way that fields appear"
ii) Click on 1 to appear 1 field in each row
data:image/s3,"s3://crabby-images/99698/99698ccb8c7481da99c8145b2c804959cc0ba97f" alt="Click on 1 to appear 1 field in each row"
iii) Click on 'number selected' to edit the fields that you want to appear in your form
data:image/s3,"s3://crabby-images/fdf48/fdf48ccb875aa7571e45a5bf42d69c83bea94e51" alt="Click on 'number selected' to edit the fields that you want to appear in your form"
iv) Click on '+Add field' if you want to include a field that didn't appear by default
data:image/s3,"s3://crabby-images/8b721/8b7215069e1880d26ccfc2d44f30f1c123789736" alt="Click on '+Add field' if you want to include a field that didn't appear by default"
v) Choose the field you want to add
data:image/s3,"s3://crabby-images/69809/69809e98b6e333f3d8fbd1aa1344979c32b2af83" alt="Choose the field you want to add"
vi) Click on Add
data:image/s3,"s3://crabby-images/092a9/092a9c284948d1cf97622fe7dcfcb7e4c28102be" alt="Click on Add"
vii) Click on a Datacard if you want to make changes to it
data:image/s3,"s3://crabby-images/9b70a/9b70a4044d812ec9d08091751aaf8493ff794e85" alt="Click on a Datacard if you want to make changes to it"
Ensure that you unlocked the Datacard so to be able to make changes
- Click on Advanced
data:image/s3,"s3://crabby-images/784e2/784e23ee93cac41f50efbcd7391b35a55a3321f8" alt="Click on Advanced"
- Click on Unlock to change properties.
data:image/s3,"s3://crabby-images/6c416/6c4161f9dbf07cb464757850864591cb08001322" alt="Click on Unlock to change properties."
viii) Position the edit form inside the container so that there is free space at the top and at the bottom of the container where the label and buttons are placed
data:image/s3,"s3://crabby-images/73777/73777726263f736ebbb0373df95bf0d5fb1d6700" alt="Position the edit form inside the container so to there is free space at the top and at the bottom of the container where the label and buttons are placed"
Step 7
Make the button ‘Submit’ functional.
We want to make the submission process smooth, with clear feedback to the user about the success or failure of their submission.
i) Click on Submit Button
data:image/s3,"s3://crabby-images/ca0f0/ca0f0bf88e8cfc2679d97bbd2f0183f52adae815" alt="Click on Submit Button"
ii) Click on OnSelect Property
data:image/s3,"s3://crabby-images/dcece/dcece458d097787ec0d57f4b6d2a9c585b77dae5" alt="Click on OnSelect Property"
iii) Set the formula
data:image/s3,"s3://crabby-images/99ce6/99ce6154b89afdfc26c78673d50b82111a484b9c" alt="Set the formula"
Code applied to the submit button:
SubmitForm(Form1);
If(
Form1.Valid,
ResetForm(Form1);
Set(isForm1Visible, false);
Notify("Form submitted successfully!", NotificationType.Success),
Notify("Form submission failed. Please check the required fields.", NotificationType.Error)
)
Let’s break this down:
- SubmitForm(Form1);
Triggers the submission of ‘Form1’. It attempts to save the data entered in the form to the connected data source.
- If(Form1.Valid,...);
Check if ‘Form1’ is valid. It returns true if all required fields are filled out correctly according to the form’s validation rules.
- ResetForm(Form1);
If the form is valid, this command clears all the input fields, preparing the form for a new entry.
- Set(isForm1Visible, false);
The pop-up form gets hidden after a successful submission.
- Notify("Form submitted successfully!" NotificationType.Success)
The notify function shows a notification with a success message to the user.
- Notify("Form submission failed. Please check the required fields.", NotificationType.Error)
If the form is not valid, a failure message is shown, indicating that the form submission failed, prompting the user to check the required fields.
Step 8
Make the button ‘Cancel’ functional.
i) Click on Cancel Button
data:image/s3,"s3://crabby-images/488ff/488ffcb1febb1057182c61029f4e58bd6f57739b" alt="Click on Cancel Button"
ii) Click on OnSelect Property
data:image/s3,"s3://crabby-images/1ab03/1ab031638269060c32d340dcfa87cb237cd4f954" alt="Click on OnSelect Property"
iii) Set the formula
data:image/s3,"s3://crabby-images/1a975/1a97585f1fd9ee7fd63a430ee15ef70d08099bf2" alt="Set the formula"
- Set(isForm1Visible, false)
Hides the form, when the cancel button is clicked. Provides users the option to exit the form if they decide not to make any changes.
Step 9
Add a rectangle to use as a background color when the pop-up appears.
** The rectangle has to be added outside the form container
i) Click on the screen you added the pop-up
data:image/s3,"s3://crabby-images/e4342/e4342b6b7b4efd7d1084f7384ac1ceb99961e68e" alt=""
ii) Click on Insert
data:image/s3,"s3://crabby-images/f0b0a/f0b0aa46d14e3e1ffadd3d0c7a9fb65b65fb8833" alt="Click on Insert"
iii) Click on Rectangle
data:image/s3,"s3://crabby-images/c836d/c836d11536734d34175df8f45fea03485d1049de" alt="Click on Rectangle"
iv) Click on More options
data:image/s3,"s3://crabby-images/06db2/06db2f3013aad1e9f7f3f9646d1770fb1236cef8" alt="Click on More options"
v) Click on Send backward until it appears down the form container you created previously
data:image/s3,"s3://crabby-images/d8b50/d8b504a5841eedb3a83b3d8871aed505728f1775" alt="Click on Send backward until it appears down the form container you created previously"
vi) This is the right order so that the rectangle appears in the background of the form
data:image/s3,"s3://crabby-images/becfb/becfbcbabb4d93f78c550dd70efb1f36e58efbe4" alt="vi) This is the right order so that the rectangle appears in the background of the form"
vii) Resize the rectangle so it covers the whole screen
data:image/s3,"s3://crabby-images/cb611/cb611e062e4565fb2bc2807890d3bdf4888402b0" alt="Resize the rectangle so it covers all the screen"
viii) Click on Color
data:image/s3,"s3://crabby-images/b49f0/b49f082d1aba102ddf18b2193eb180bcb1050687" alt="Click on Color"
ix) Set a light gray color
data:image/s3,"s3://crabby-images/2be65/2be656d28a83db7fade9f994c420a3b91ff8d5c4" alt=""
x) Click on Property dropdown
data:image/s3,"s3://crabby-images/03f7c/03f7c8e2c224fcc6dcaea8db1ebc2cf1b527f2ab" alt="Click on Property dropdown"
xi) Click on Visible
data:image/s3,"s3://crabby-images/ae49d/ae49d2a37d67ff113da73c8d17ab41a16ad6627c" alt="Click on Visible"
xii) Set the variable 'isForm1Visible' that controls when the rectangle will appear or disappear
data:image/s3,"s3://crabby-images/fa188/fa18820127954e2e979093596cc0b7e1bae6c2b9" alt=""
Conclusion
Creating a pop-up window in Powerapps involves designing a hidden form, setting up a button to toggle its visibility, and adding functionality like submission or cancellation.
By using variables to manage the visibility of the pop-up and connecting actions to buttons, you can effectively improve your app’s interactivity and provide a better user experience.
If you are intrested in learing more about PowerApps you can check the following tutorials: