This tutorial will guide you through the steps to create a collapsible side-navigation menu in PowerApps. Side-navigation menus are a great way to organize app content, making it easier for users to access different sections without cluttering the screen.
By the end of this guide, you’ll learn how to create a collapsible menu that can enhance the user experience by saving space and improving navigation.
Features of the Menu
This menu will be used in the app and will have these two features:
- Expand and collapse the menu
data:image/s3,"s3://crabby-images/e05a4/e05a473a74a87e7fc314ad27031dd56de5533edc" alt="Image: Expand the menu"
data:image/s3,"s3://crabby-images/47276/47276e098c57763a32996b399867f7e9615d2528" alt="Image: Collapse the menu"
- Change between screens
data:image/s3,"s3://crabby-images/497d9/497d926e6245adcbba1d1c0a001e160c0f7c3d89" alt="Image: New incidents page"
data:image/s3,"s3://crabby-images/8ea53/8ea53f4a64ce6a70fe2d6a2d94485156e71709af" alt="Image: New incidents reported page"
data:image/s3,"s3://crabby-images/ee0d3/ee0d38b9732fc3b34f962c9ed046afef319f5a72" alt="Image: Locations page"
How to create it step by step.
We will create the menu without the expand/collapse feature, and after creating a simple menu, we will make the one with this feature too.
First of all, the menu is a component, so the first step is to create a new component and name it. The name of my component is SideNav (and SideNav_Collapsable for the one that collapses).
Here you can see how the component is going to look like in the end:
data:image/s3,"s3://crabby-images/601f2/601f2474b1eed4e2322e2c8f0d0ba6b63a131c1a" alt="Image: SideNav"
Adding Properties
In order for the component to work we have to add some custom properties:
data:image/s3,"s3://crabby-images/027cb/027cbe0f36e11a1478d790604c4b95322eb80b90" alt="Image: Side Nav custom properties"
- The MenuContent is needed because inside it we will store the data about the buttons that will change the screens, for example, the name, the icon, etc.:
data:image/s3,"s3://crabby-images/7481e/7481e97159dd156dd521d3bb17d0ad04bf5b1ef7" alt="Image: Menu Content"
- Inside the MenuContent we will create a table and add all the necessary information. This can be different from app to app because different apps need different menus
data:image/s3,"s3://crabby-images/fe8ae/fe8aec56eadc4f38c6fb534c27cdd2b8dcf26a3d" alt="Image: Adding code to the Menu Content"
- The hover fill will allow us to make the buttons slightly change color when hovered. :
data:image/s3,"s3://crabby-images/54641/54641c93033e056cc8d128d2d1022fbc409fd84a" alt="Image: Click on hover fill"
- Just like the hover fill the pressed fill will do a similar thing when the button is pressed:
data:image/s3,"s3://crabby-images/7e746/7e74682be568a4b4b4335092440dcfe2e7ce93e9" alt="Image: Click on pressed fill"
- When we are in our app we need to know what screen we are on. In order to achieve that we will make the selected icon from the menu have a slightly darker color. That’s why the CurrentMenuID is needed:
data:image/s3,"s3://crabby-images/dfd94/dfd94b80bd99f65d941ccd216f307673adefd469" alt="Image: Click on CurrentMenuID"
6. Apart from the CurrentMenuID we will also need SelectedIconBG:
data:image/s3,"s3://crabby-images/1e4dc/1e4dc8a51853274d46743827053aa6ea9d3184db" alt="Image: Click on SelectedIconBG"
- And finally a BaseIconColor:
data:image/s3,"s3://crabby-images/9d6a5/9d6a56db593bf46d9213c96f24831ad0b999408c" alt="Image: Click on BaseIconColor"
- After creating all these custom properties we need to write the formulas of them according to what we want to achieve.
Building the Component
Now that we have created the custom properties it’s time to start building the component.
- Create a gallery:
data:image/s3,"s3://crabby-images/ff965/ff9652226faea82c81e6b58645c5adb456d43905" alt="Image: Click on Gallery2"
- Set the gallery’s item property as: SideNav.MenuContent
- Inside the gallery put two containers
data:image/s3,"s3://crabby-images/b1752/b1752e5da6752b37af5e7246aa0d909c65d42c25" alt="Image: Adding a container in the gallery"
data:image/s3,"s3://crabby-images/8be09/8be093178f3376fcf19a6d4b8309fbd81d3a6fbf" alt="Image: Adding a container in the gallery"
- Inside the second container add:some text
- A button and set its OnSelect property: Navigate(ThisItem.PageNavigation)
- An image
data:image/s3,"s3://crabby-images/2087e/2087ef414653c42c3d8e375ac0e553f918683faf" alt="Image: Adding a button in the container"
data:image/s3,"s3://crabby-images/f9184/f918492af9078c8bf8ed9b6c638aa289b103ba45" alt="Image: Adding an image in the container"
data:image/s3,"s3://crabby-images/f8801/f8801a144b488b5509cd1bd20211595b067c6669" alt="Image: Adding a code for the image"
After these steps, the menu should be almost ready, some more things should be added after the menu enters the app.
Adding the expand/collapse feature
Now let's see how we can add the expand/collapse feature
- Create a new custom property
data:image/s3,"s3://crabby-images/78d08/78d087a36f53119b6534d1214460edcd992767f7" alt="Image: Create a new custom property"
- Set the MenuExpanded as: varMenuExpanded
data:image/s3,"s3://crabby-images/c00aa/c00aa36eaaf12babdfefd1e3dc4930e4de5696c9" alt="Image: Set the MenuExpanded as: varMenuExpanded"
- Create a new container
data:image/s3,"s3://crabby-images/c2748/c274829f44d3626d90afacbcbf27bdccb5aa4ceb" alt="Image: Click on a container"
- Inside the container add the button that will expand/collapse the menu
data:image/s3,"s3://crabby-images/a2afe/a2afe47b00577060e001b00e32a8de30993a2327" alt=""
- Set the buttons OnSelect property as: Set(varMenuExpanded,
!varMenuExpanded)
data:image/s3,"s3://crabby-images/f2972/f2972879fca784e7048de136b1185ce0f63020f7" alt="Image: Set the buttons OnSelect property as: Set(varMenuExpanded,!varMenuExpanded)"
- Add an image
data:image/s3,"s3://crabby-images/37e68/37e68d078264a5f58bc3dbe3f00c904454e5f687" alt="Image: Click on an image"
- Set its property as:
data:image/s3,"s3://crabby-images/94384/9438449eb32ae690e62f4d091c09b6bcde01d0ab" alt="Image: Setting a property in the image"
- Finally set the menus width property as:
If(SideNav_Collapsable.MenuExpanded,180,70)
Now to make it fully functional we need to add a few more touches to the app we want to create
Adding the final touches
- Add this to the app’s formula property:
data:image/s3,"s3://crabby-images/edbd2/edbd28a3febd6c064e9b2b2981d801cf85dc972f" alt="Image: Adding a property in the app's formula"
- After adding the menu to each screen go to every one of them and give a unique currentMenuID
data:image/s3,"s3://crabby-images/777f7/777f708aa7759db85f9ee1c3a4ee6a6ed518f7a8" alt="Image: Adding unique currentMenuID to each screen"
data:image/s3,"s3://crabby-images/a321c/a321cd208282b12f8f69b11ec4e6c4c0f01eec7c" alt="Image: Adding unique currentMenuID to each screen"
Conclusion
Creating a collapsible side-navigation menu in PowerApps can greatly improve the usability of your app. It provides a clean and organized layout and gives users quick access to key features.Having this functionality in place will not only make your app look professional but also give you a smooth experience.
Don't stop here! Keep learning with these related tutorials: