When creating a custom form in Power Apps from a SharePoint list, multi-select columns are automatically rendered as combo boxes by default.
While this default functionality works, I wanted to explore better UI options by converting these combo boxes to checkboxes for improved user experience.
Multi-Select Columns in SharePoint
SharePoint lists allow you to create columns that support multiple item selection. Here’s how to set it up:
First, select “Choice” in the column settings:
data:image/s3,"s3://crabby-images/9d5ac/9d5ac8e713392a601b7cb9a1b34dde5aef9b3fa7" alt="SharePoint column type selection showing Choice option"
Then, enable the “Allow multiple selections” option:
data:image/s3,"s3://crabby-images/55028/550288ae82368b4db678c39596a4329ffe3494e6" alt="SharePoint multiple selection configuration"
This is how it appears in the standard SharePoint form:
data:image/s3,"s3://crabby-images/ecc07/ecc07dfca73f91f27312e5e7f11caa739fb56b9b" alt="Standard SharePoint multi-select form view"
Default Behavior in Power Apps Custom Forms
When you create a custom form in Power Apps using this SharePoint list, the multi-select column appears as a combo box:
data:image/s3,"s3://crabby-images/4d9b8/4d9b8685f60b073196f9573c7a8188e8e1f27095" alt="Power Apps default combo box display"
This is how it looks when multiple items are selected:
data:image/s3,"s3://crabby-images/a45a8/a45a8b889f532f7fed8c53acf549b224f5583e2c" alt="Power Apps combo box with multiple selections"
While this default combo box functionality works as intended, the user interface isn’t particularly intuitive or user-friendly. That’s why I decided to explore alternative controls to replace this combo box with something more user-friendly.
Implementing Multi-Select with List Box
Let’s start by converting the combo box to a list box. Here’s the step-by-step process:
First, add a list box control inside the DataCard of your choice column:
data:image/s3,"s3://crabby-images/aa3f7/aa3f76dc6cf5dc5f3d6dbe78a964c602edf202be" alt="Adding list box to DataCard in Power Apps"
Unlock the card for editing:
data:image/s3,"s3://crabby-images/80d19/80d193f77d013261bc79327098c75d1fab604309" alt="Unlocking DataCard in Power Apps"
Locate the Items property formula from the original combo box:
data:image/s3,"s3://crabby-images/3b855/3b85598da3fd2bbd246a274875d2e877402c41df" alt="Original combo box Items property"
Copy and paste this formula into the Items property of your new list box:
data:image/s3,"s3://crabby-images/14e43/14e432a8bf5a82181c32b4cb537586c280eadad4" alt="Copying formula to list box Items property"
Next, modify the DataCard’s Update property to use the SelectedItems property of the list box:
data:image/s3,"s3://crabby-images/02144/021449cdbe763a9db8e4bd656c5758ee04261e7c" alt="Modifying DataCard Update property"
Finally, remove the original combo box and adjust the X and Y coordinates of the list box to complete the setup:
data:image/s3,"s3://crabby-images/05cfc/05cfcfa582784151ae6f493467aad9ec00b33ef0" alt="Final list box positioning"
Now you can successfully register multiple selections using the list box:
data:image/s3,"s3://crabby-images/7ba50/7ba503a4a54ac51e06b0a9eb92e58e287b1293c3" alt="Working multi-select list box demonstration"
Implementing Multi-Select with Checkboxes
Next, let’s explore how to implement the multi-select functionality using checkboxes.
While we could simply place a fixed number of checkboxes directly in the DataCard, this approach would require maintenance whenever we add new choices in SharePoint. That’s not an ideal solution for long-term maintenance.
Instead, I created a more dynamic solution by combining a gallery control with checkboxes to achieve this layout:
data:image/s3,"s3://crabby-images/aecd5/aecd5a6c4ca0ed8f080d5b5f0e4568273cc1cec2" alt="Gallery with checkboxes layout in Power Apps"
When you add new choices in SharePoint:
data:image/s3,"s3://crabby-images/18d0d/18d0d4090dff29cc117da5e83f9139003b95e886" alt="Adding new choices in SharePoint list settings"
The checkboxes automatically update to reflect these changes:
data:image/s3,"s3://crabby-images/5883c/5883c602b170496f95e2ed6c8511ffe25edaf700" alt="Updated checkbox gallery showing new options"
Step 1: Adding Gallery and Checkboxes
First, let’s add a gallery control to the form. When attempting to add an empty gallery inside the DataCard:
data:image/s3,"s3://crabby-images/54c8a/54c8a7541baba5f36250c8f07893b389727b6cfb" alt=""
You’ll notice the gallery appears outside the DataCard. To fix this, cut the gallery:
data:image/s3,"s3://crabby-images/dbdac/dbdac08d11f96495ead8f7629836ec6de7f4142a" alt=""
Then paste it inside the DataCard:
data:image/s3,"s3://crabby-images/b3c84/b3c842b1643d1ff2131a1826eb419ffb0e6624fd" alt=""
Now the gallery is properly positioned within the DataCard:
data:image/s3,"s3://crabby-images/92352/9235254aa091b68416e24aaaabce58236d54c103" alt=""
Next, copy the Items property from the original combo box and paste it into the gallery’s Items property:
data:image/s3,"s3://crabby-images/fab22/fab229563bcb9560e20a9763e7b89cd1f14024d5" alt=""
When you add a checkbox control inside the gallery:
data:image/s3,"s3://crabby-images/88b87/88b879731416e297e3a511355dc89493b17ed38b" alt=""
This creates the initial checkbox layout:
data:image/s3,"s3://crabby-images/49e09/49e097990351cfeb93088deea0c022adbb329c52" alt=""
You might only see one checkbox because the gallery’s template size is too large. Adjust the TemplateSize to match the checkbox height plus padding:
data:image/s3,"s3://crabby-images/3d43d/3d43d55febba07dcf9ea8b0468254d1d675b649b" alt=""
Set the checkbox’s X and Y positions to 0 to display all options:
data:image/s3,"s3://crabby-images/57446/574461ba9975d384a1443c35b76780d3044331f4" alt=""
Finally, set the checkbox’s Text property to ThisItem.Value to display the option text properly, creating a clean and organized appearance:
data:image/s3,"s3://crabby-images/e44a7/e44a7d57278727a5e6e8f27fca500095b1e70402" alt=""
Step 2: Connecting SharePoint List with Gallery
When the form opens in “New” mode, all checkboxes should be false, and in “Edit” mode, they should be true or false based on the item’s existing values.
First, create a collection called “selectedItems”. When the custom form opens in “New” mode, clear this collection:
data:image/s3,"s3://crabby-images/d2359/d23593f27d0f108069d1c410bbc69cb2651e2df6" alt=""
When the custom form opens in “Edit” mode, use ClearCollect to add the current selection state of that item:
data:image/s3,"s3://crabby-images/82e80/82e806632a28451e9a9d8c1444062ead7822ac87" alt=""
Then, set the checkbox’s Default property to check if the “ThisItem.Value” (option name) exists in the “selectedItems” collection:
data:image/s3,"s3://crabby-images/e2767/e2767c0ad600967af938d9c8892b8e22fee5ce4b" alt=""
This ensures that when creating a new list item, no checkboxes are selected:
data:image/s3,"s3://crabby-images/02d3c/02d3cf635670fa322acc03695d0433141dbed305" alt=""
And when editing, it reproduces the current selection state:
data:image/s3,"s3://crabby-images/70894/708946ca3dd621c0a79cdf21adc7695fb38459cc" alt=""
Next, use the checkbox’s OnCheck event to add checked options to selectedItems:
data:image/s3,"s3://crabby-images/73d7a/73d7aafef2a7f20c79385c61d2ff88b14014781d" alt=""
Use OnUncheck to remove unchecked options from selectedItems, maintaining the check states in the collection:
data:image/s3,"s3://crabby-images/e8d48/e8d4805cfa8d453723278301040024fc34b31fe4" alt=""
Finally, complete the setup by adding this selectedItems to the DataCard’s Update property formula:
data:image/s3,"s3://crabby-images/8b9f4/8b9f4433d3de3919fb4a6a3c739acedb3485a924" alt=""
Testing the Implementation
First, when adding a new item:
data:image/s3,"s3://crabby-images/3eb92/3eb92ff59a86dccda43704179a79329620948509" alt=""
Multiple selections are successfully registered:
data:image/s3,"s3://crabby-images/0dbd0/0dbd0c9f91c5a0087703469fdb1ce68c9fce5149" alt=""
When editing the item, the previous selection state is properly restored:
data:image/s3,"s3://crabby-images/aecd5/aecd5a6c4ca0ed8f080d5b5f0e4568273cc1cec2" alt=""
After making additional selections and clicking save:
data:image/s3,"s3://crabby-images/f799c/f799cdba70d45a2cc1257e66c2c339a133a0f777" alt=""
The newly selected options are successfully registered, completing our implementation:
data:image/s3,"s3://crabby-images/60be5/60be53050b0e45340ce68a2d0ed35bbb63634667" alt=""
コメント