Hi, im using SortByColumn in a Gallery, and i am going to create buttons with different for different sort order, eg button for Title, Created, Location, Created by, Priority Requester. My variable is varSortColumn.
I use the set(varSortColumn,"Title") to set the column name to sort by.
In the Item in the Gallery i use:
SortByColumns(Filter(Serviceoppdrag;StartsWith(Tittel;TextSearchBox1.Text);Active=false);varSortColumn;If(
SortDescending1;Descending;Ascending))
When i use a variable, and not the "hord code" name of the column i get an delegation warning. Is there a way to use variable without getting the delegation issue ? When i use the column name, there is not any delegation problem, only when i use a variable.
Solved! Go to Solution.
Hi,
I'm not sure why your original formula didn't work to be honest - I'm the same as @rebeccas in that I usually just use a variable and it works?
This was a workaround to get it to work in your case where variable was not being detected correctly - I would give @rebeccas 's video a watch to see if you can use the same method within your App, otherwise use the method we've covered here for sorting the logic out beforehand.
Thanks
@iAm_ManCat |
My blog |
Please 'Mark as Solution' if someone's post answered your question and always 'Thumbs Up' the posts you like or that helped you! |
Thanks! |
Hi, thanks! I have tried Rebeccas methode, with a variable for the column that are going to be sorted, but i get the delegation problem/warning (and i have > 2000 items in the list/table). Im looking for a methode to use avariables, without getting the delegation problem.
I think using conditions looking at the variable with as many else steps as you need for all the columns to sort on is going to be the only option to avoid delegation. That said, I don't see why you need a variable for each column as that's just extra work. Just make your condition "If(varSort = "ColumnName", SortByColumns(..." where your specifying that column name in each condition.
I'm having the same issue and going to give that a try. My formula is very complex already so I really don't want to have to go this route but variables and label values are not working - I tried where a label's text property is the variable and then referenced the label.text in the formula but received the same delegation warning.
BTW - Rebecca's video shows she has a delegation warning as well (see attached).
I find apps run slow with trying to show that much data so I typically try to limit mine with different filtering options and other ways so delegation warnings are not typically a concern of mine. They aren't anything to be concerned with if you have less than 500 items. I have one or two that I need to show more data in which case I don't use Filter and use the search instead to avoid that. You just have to be careful to know when those are something that matter (as in will have any effect on your data/app) or not.
Yes, I'm seeing an obvious performance change when adding in the conditions to sort for 2 of my 8 gallery columns when the SharePoint list has 1400 or so rows. In my case I have a gallery that is using a collection as the datasource if the status of the item is not Completed or Cancelled (where there will never be more than 500) and using the SP list directly for the Completed/Cancelled items. I had to change this due to app row limits pulling all items into the collection with using the Search function (which is not delegable with SharePoint as the datasource). I think you stated this backwards, @rebeccas with Filter being delegable for SharePoint, but not Search. ...or maybe you were referring to use a search box with a StartsWith type of filter.
Anyway, I have even changed the design so that items from the active SP list get sent to a separate "archive" SP list once the status is Completed/Cancelled to improve performance and more logically separate the two types of filtering I'm doing. The active items have a search box that can use multiple terms with a delimiter that is a fantastic experience for the user, but uses functions that require a collection to be used to avoid delegation issues. When viewing the archived data I have combobox filter options for the columns, which is more clicks and more traditional than using the multi-term search box but works just fine. Trying to add in conditions for sorting the columns turns out to be more of a pain than I thought given neither a variable or label value can be used as the reference for sorting without delegation. I can create the condition before the filter of the datasource, but not only does this create performance issues but it requires double the formula just to have options to sort on 2 columns. Thus, if I add the option for all 8 columns my formula is going to be extremely lengthy and I haven't even added the option to filter in "my stuff" on this archive view. My screenshot shows my formula now for the gallery.items with just 2 columns having sorting active for the completed/cancelled view (highlighted) with the remainder of the formula for the active view.
I was trying to avoid having multiple galleries or screens to view each datasource so there wouldn't be redundencies that I'd need to update twice if updates were needed to the core gallery elements, but now I'm thinking I may need to go that route so performance isn't so slow and so my formulas aren't so lengthy. I am spending more time on getting this right the first time as this will be the model for many other apps we create that have a similar data structure where completed/cancelled status items are just going to keep growing.
*Edit*
The attachments don't show for me so I don't know if they show for others, so here's the formula in text to get an idea of how long it would be if I used this route for sorting options on all 8 columns. What is highlighted in the screen shot is italicized below:
If(gvStatus="Complete"||gvStatus="Cancelled",If(gvSortPriority="CIType_Txt",SortByColumns(Filter('Dev - CI Projects','CI Status'.Value=gvStatus&&StartsWith(Title,LblTitleFilter1.Text)&&StartsWith(CIType_Txt,LblTypeFilter1.Text)&&StartsWith(Responsible_Txt,LblResponsibleFilter1.Text)&&StartsWith(Location_Txt,LblLocationFilter1.Text)&&StartsWith(Area,LblAreaFilter1.Text)&&StartsWith(Waste_Txt,LblWasteFilter1.Text)&&StartsWith(Priority_Txt,LblPriorityFilter1.Text)&&StartsWith(DMAIC_Txt,LblDMAICFilter1.Text)),"CIType_Txt",If(gvSortDescending,Ascending,Descending),"Priority_Txt",Ascending,"Benefit",Descending,"PlanCompletion",Ascending),
If(gvSortPriority="Title",SortByColumns(Filter('Dev - CI Projects','CI Status'.Value=gvStatus&&StartsWith(Title,LblTitleFilter1.Text)&&StartsWith(CIType_Txt,LblTypeFilter1.Text)&&StartsWith(Responsible_Txt,LblResponsibleFilter1.Text)&&StartsWith(Location_Txt,LblLocationFilter1.Text)&&StartsWith(Area,LblAreaFilter1.Text)&&StartsWith(Waste_Txt,LblWasteFilter1.Text)&&StartsWith(Priority_Txt,LblPriorityFilter1.Text)&&StartsWith(DMAIC_Txt,LblDMAICFilter1.Text)),"Title",If(gvSortDescending,Ascending,Descending),"Priority_Txt",Ascending,"Benefit",Descending,"PlanCompletion",Ascending),SortByColumns(Filter('Dev - CI Projects','CI Status'.Value=gvStatus&&StartsWith(Title,LblTitleFilter1.Text)&&StartsWith(CIType_Txt,LblTypeFilter1.Text)&&StartsWith(Responsible_Txt,LblResponsibleFilter1.Text)&&StartsWith(Location_Txt,LblLocationFilter1.Text)&&StartsWith(Area,LblAreaFilter1.Text)&&StartsWith(Waste_Txt,LblWasteFilter1.Text)&&StartsWith(Priority_Txt,LblPriorityFilter1.Text)&&StartsWith(DMAIC_Txt,LblDMAICFilter1.Text)),"Priority_Txt",If(gvSortDescending,Ascending,Descending),"Priority_Txt",Ascending,"Benefit",Descending,"PlanCompletion",Ascending))),
SortByColumns(Filter(colCIPortfolio,If(gvMyStuff,Responsible_Txt=Office365Users.MyProfileV2().displayName&&'CI Status'.Value=gvStatus&&IsBlank(Find("0",Concat(Filter(Split(InputSearch.Text,","//or any delimiter.
),!IsBlank(Result)),If(TrimEnds(Result) in CIType_Txt||TrimEnds(Result) in Title||TrimEnds(Result) in Responsible_Txt||TrimEnds(Result) in Location_Txt||TrimEnds(Result) in Area||TrimEnds(Result) in Waste_Txt||TrimEnds(Result) in Priority_Txt||TrimEnds(Result) in DMAIC_Txt,// etc.
"1","0"))))||InitiatedBy_Txt=Office365Users.MyProfileV2().displayName&&
'CI Status'.Value=gvStatus&&IsBlank(Find("0",Concat(Filter(Split(InputSearch.Text,","//or any delimiter.
),!IsBlank(Result)),If(TrimEnds(Result) in CIType_Txt||TrimEnds(Result) in Title||TrimEnds(Result) in Responsible_Txt||TrimEnds(Result) in Location_Txt||TrimEnds(Result) in Area||TrimEnds(Result) in Waste_Txt||TrimEnds(Result) in Priority_Txt||TrimEnds(Result) in DMAIC_Txt,// etc.
"1","0")))),
'CI Status'.Value=gvStatus&&IsBlank(Find("0",Concat(Filter(Split(InputSearch.Text,","//or any delimiter.
),!IsBlank(Result)),If(TrimEnds(Result) in CIType_Txt||TrimEnds(Result) in Title||TrimEnds(Result) in Responsible_Txt||TrimEnds(Result) in Location_Txt||TrimEnds(Result) in Area||TrimEnds(Result) in Waste_Txt||TrimEnds(Result) in Priority_Txt||TrimEnds(Result) in DMAIC_Txt,// etc.
"1","0")))))),gvSortPriority,If(gvSortDescending,Ascending,Descending),"Priority_Txt",Ascending,"Benefit",Descending,"PlanCompletion",Ascending))
I only have a few that have a ton of data. Some of it is just simply I haven't had much need...we use PowerApps for more active items and haven't needed to use it much for items inactive (may eventually) but I do have a few that have a ton of data in them (under 2,000 but close to it).
Yes...I did get those backwards...on search and filter. I still use Search anyhow if I don't have over 500 items because it is SO much cleaner and faster.
One thing that might help is I often use the same screen for several different variations of filtered data but what they select on the screen before is what decides what shows. I have the screen before set a variable that I will "Filter" off of and I put that in the ClearCollect part...not down on the gallery. I also have a few that they can flip between what they see on the screen and it just updates the collection each time they select a different "tab" but it is the same gallery just changing what they see in it.
I am less experienced in apps with a lot of data. I have close to 50 apps being actively used at this time and I think 3 of them will have over 1,000 rows at any given time....all the rest are closer to the 500 and under range.
I do what I can to keep the data in the app as lean as possible - to your statement of filtering off first where possible. If you can follow that one formula you can see there's a lot happening for a fairly simplified view to the user. The collection I have is already filtered from the source.
...and yes, search is way better if it can be used, even if old schooler's say they prefer column header drop-down filtering options. I get a kick out of the thought that is "easier" to click into each column header and choose a filter from a list when I can have a single search box filter on all columns using multiple terms. I just wish this option was delegable.
For the current state of the first app I've developed search is fine and works great, but it is important for some to access the completed items which will only continue to grow well past the Power Apps row limit within the next few months. Given other apps that are being developed will have similar growth and needs for those other items we need to have a good solid model in place that scales.
Seems at this stage no matter the approach it's a bit of work to get a lot of data accessible in Power Apps without killing performance and/or running into delegation issues.
Thanks for the input.
@TrulsB
SORTBYCOLUMNS cannot be delegated when a variable is used as the 2nd argument.
However, we can use the WITH function to achieve the desired result with the SWITCH and SORT functions. The code below can be delegated and will return the first 2,000 records just like SORTBYCOLUMNS would typically do. You will have to write a SWITCH case for each sortable column name but the effort it takes to do that is minimal.
With(
{wFilterRecords: Filter(Serviceoppdrag; StartsWith(Tittel;TextSearchBox1.Text); Active=false)};
Switch(
varSortColumn,
"ColumnName1",
Sort(wFilterRecords, "ColumnName1", If(SortDescending1;Descending;Ascending));
"ColumnName2",
Sort(wFilterRecords, "ColumnName2", If(SortDescending1;Descending;Ascending));
"ColumnName3",
Sort(wFilterRecords, "ColumnName3", If(SortDescending1;Descending;Ascending));
)
)
If you would like a full tutorial on how to build sort controls in your app check out this article I wrote. A preview image is shown below.
Article - Power Apps Gallery Sort Controls
https://matthewdevaney.com/power-apps-gallery-sort-controls/
---
Please click "Accept as Solution" if my post answered your question so that others may find it more quickly. If you found this post helpful consider giving it a "Thumbs Up."
Very intuitive and yet another Delegation Management Strategy (DMS is the new acronym for workaround . . .) using With().
It is probably also worth linking to my community post to elaborate on what you are doing. Certainly deserves an acceptance.
Still not liking the Switch function where we are already using variables but it is a hell of a lot better than if()-statements 👍💪
Join us for the first-ever the Biz Apps Community User Group meeting live from the Power Platform Conference! This one hour user group meeting is all about discovering the value and benefits of User Groups! Discover how you can find a group in your local area or about specific topics where you can learn new skills and meet like-minded people as a user group member. Hear from User Group leaders about why they do what they do and what resources they receive to help them succeed as community ambassadors. If you have never attended a User Group meeting before, this will be a great introduction! We hope you are inspired to find a group that meets your unique interests! October 5th at 2:15 pm Pacific time If you're attending #MPPC23 in Las Vegas, join us in person! Find out more here: https://powerplatformconf.com/#!/session/Biz%20Apps%20Community%20User%20Group%20Meeting%20-%20Live%20from%20MPPC/6172 Not at MPPC23? Attend vvirtually by registering here: https://aka.ms/MPPCusergroupmeeting2023 If you can't attend this meeting live, don't worry! We will record this meeting and share it with the Community at powerusers.microsoft.com
We are excited to kick off our new #TuesdayTIps series, "Back to Basics." This weekly series is our way of helping the amazing members of our community--both new members and seasoned veterans--learn and grow in how to best engage in the community! Each Tuesday, we will feature new areas of content that will help you best understand the community--from ranking and badges to profile avatars, from Super Users to blogging in the community. Our hope is that this information will help each of our community members grow in their experience with Power Platform, with the community, and with each other! This Week's Tips: Account Support: Changing Passwords, Changing Email Addresses or Usernames, "Need Admin Approval," Etc.Wondering how to get support for your community account? Check out the details on these common questions and more. Just follow the link below for articles that explain it all.Community Account Support - Power Platform Community (microsoft.com) All About GDPR: How It Affects Closing Your Community Account (And Why You Should Think Twice Before You Do)GDPR, the General Data Protection Regulation (GDPR), took effect May 25th 2018. A European privacy law, GDPR imposes new rules on companies and other organizations offering goods and services to people in the European Union (EU), or that collect and analyze data tied to EU residents. GDPR applies no matter where you are located, and it affects what happens when you decide to close your account. Read the details here:All About GDPR - Power Platform Community (microsoft.com) Getting to Know You: Setting Up Your Community Profile, Customizing Your Profile, and More.Your community profile helps other members of the community get to know you as you begin to engage and interact. Your profile is a mirror of your activity in the community. Find out how to set it up, change your avatar, adjust your time zone, and more. Click on the link below to find out how:Community Profile, Time Zone, Picture (Avatar) & D... - Power Platform Community (microsoft.com) That's it for this week. Tune in for more Tuesday Tips next Tuesday and join the community as we get "Back to Basics."
Welcome to our September 2023 Newsletter, where we highlight the latest news, product releases, podcasts, upcoming events, and the great work of our Power Platform Community members. As usual, please make sure you follow our News & Announcements in the Community to stay up to date. Another great way to connect is to join our Power Platform Community on LinkedIn. You can join our LInkedIn community here. MPPC's Got Power - Submissions end September 28th! Are you ready to showcase your skills at the Microsoft Power Platform Conference in Las Vegas? Don't miss out on the "MPPC's Got Power" talent show, a grand celebration of connection, inspiration, and shared journeys. Whether you're a technical innovator, a talented storyteller, or have a hidden creative side, we want to see what you've got! With three categories to choose from, you have the chance to shine on stage and make your mark in the Microsoft Power Platform community. Click the GIF to sign up by Thursday 28th September to be part of an unforgettable MPPC23 experience. Now is your time to shine! Check Out the Low Code Approach Podcast Give the Low Code Approach Podcast a listen! Hosted by Sean Fiene, Wendy Haddad, and Kenric Auguillard, this innovative show shines a light on how Microsoft MVPs, product team members, and Community users are building exciting solutions using Microsoft Power Platform. Plus, with guests like Kartik Kanakasabesan, April Dunnam, Ricardo Duncan Jr., Sonja Gu, Phil Topness, Shane Young and more, this weekly show is a must for all you Business Applications enthusiasts out there. Click the image below to check it out! COMMUNITY HIGHLIGHTS Check out the most active Community users for August 2023. These hardworking members are posting regularly, answering questions, writing blogs, giving kudos, and providing top solutions in their communities across Power Platform. Huge thanks to these amazing community members for their great contributions last month! trice602poweractivateLaurensMWarrenBelzAmikBCBuizerSamLedcreativeopinion timlExpiscornovusManishSolankiMattJimisonfernandosilvaMisterMarkPstork1saudali_25hafizsultan242Lucas001ragavanrajanp_doc UPCOMING EVENT: 365 EDUCON CHICAGO Whether you're new to Microsoft 365, Power Platform and SharePoint, or an experienced power user, admin or developer, 365 EduCon has content designed to fit your experience level and area of interest. Their workshops and sessions are taught by Microsoft Certified Trainers, MVPs, Regional Directors, and Engineers. Find out more and register here: Home - Microsoft 365 EduCon Chicago - A Microsoft 365 Conference.
Are you attending the Microsoft Power Platform Conference 2023 in Las Vegas? If so, we invite you to join us for the MPPC's Got Power Talent Show! Our talent show is more than a show—it's a grand celebration of connection, inspiration, and shared journeys. Through stories, skills, and collective experiences, we come together to uplift, inspire, and revel in the magic of our community's diverse talents. This year, our talent event promises to be an unforgettable experience, echoing louder and brighter than anything you've seen before. We're casting a wider net with three captivating categories: Demo Technical Solutions: Show us your Power Platform innovations, be it apps, flows, chatbots, websites or dashboards... Storytelling: Share tales of your journey with Power Platform. Hidden Talents: Unveil your creative side—be it dancing, singing, rapping, poetry, or comedy. Let your talent shine! Got That Special Spark? A Story That Demands to Be Heard? Your moment is now! 🚀 Sign up to Showcase Your Brilliance: https://aka.ms/MPPCGotPowerSignUp 🔥 Deadline for submissions: Thursday, Sept 28th How It Works: Submit this form to sign up: https://aka.ms/MPPCGotPowerSignUp We'll contact you if you're selected. Get ready to be onstage! The Spotlight is Yours: Each participant has 3-5 minutes to shine, with insightful commentary from our panel of judges. We’re not just giving you a stage; we’re handing you the platform to make your mark. Be the Story We Tell: Your talents and narratives will not just entertain but inspire, serving as the bedrock for our community’s future stories and successes. Celebration, Surprises, and Connections: As the curtain falls, the excitement continues! Await surprise awards and seize the chance to mingle with industry experts, Microsoft Power Platform leaders, and community luminaries. It's not just a show; it's an opportunity to forge connections and celebrate shared successes. Event Details: 📆 Date and Time: Wed Oct 4th, 6:30-9:00PM 📍 Location: MPPC23 at the MGM Grand, Las Vegas, NV, USA
The Reading Dynamics 365 and Power Platform User Group is a community-driven initiative that started in September 2022. It has quickly earned recognition for its enthusiastic leadership and resilience in the face of challenges. With a focus on promoting learning and networking among professionals in the Dynamics 365 and Power Platform ecosystem, the group has grown steadily and gained a reputation for its commitment to its members! The group, which had its inaugural event in January 2023 at the Microsoft UK Headquarters in Reading, has since organized three successful gatherings, including a recent social lunch. They maintain a regular schedule of four events per year, each attended by an average of 20-25 enthusiastic participants who enjoy engaging talks and, of course, pizza. The Reading User Group's presence is primarily spread through LinkedIn and Meetup, with the support of the wider community. This thriving community is managed by a dedicated team consisting of Fraser Dear, Tim Leung, and Andrew Bibby, who serves as the main point of contact for the UK Dynamics 365 and Power Platform User Groups. Andrew Bibby, an active figure in the Dynamics 365 and Power Platform community, nominated this group due to his admiration for the Reading UK User Group's efforts. He emphasized their remarkable enthusiasm and success in running the group, noting that they navigated challenges such as finding venues with resilience and smiles on their faces. Despite being a relatively new group with 20-30 members, they have managed to achieve high attendance at their meetings. The group's journey began when Fraser Dear moved to the Reading area and realized the absence of a user group catering to professionals in the Dynamics 365 and Power Platform space. He reached out to Andrew, who provided valuable guidance and support, allowing the Reading User Group to officially join the UK Dynamics 365 and Power Platform User Groups community. One of the group's notable achievements was overcoming the challenge of finding a suitable venue. Initially, their "home" was the Microsoft UK HQ in Reading. However, due to office closures, they had to seek a new location with limited time. Fortunately, a connection with Stephanie Stacey from Microsoft led them to Reading College and its Institute of Technology. The college generously offered them event space and support, forging a mutually beneficial partnership where the group promotes the Institute and encourages its members to support the next generation of IT professionals. With the dedication of its leadership team, the Reading Dynamics 365 and Power Platform User Group is poised to continue growing and thriving! Their story exemplifies the power of community-driven initiatives and the positive impact they can have on professional development and networking in the tech industry. As they move forward with their upcoming events and collaborations with Reading College, the group is likely to remain a valuable resource for professionals in the Reading area and beyond.
As the sun sets on the #SummerofSolutions Challenge, it's time to reflect and celebrate! The journey we embarked upon together was not just about providing answers – it was about fostering a sense of community, encouraging collaboration, and unlocking the true potential of the Power Platform tools. From the initial announcement to the final week's push, the Summer of Solutions Challenge has been a whirlwind of engagement and growth. It was a call to action for every member of our Power Platform community, urging them to contribute their expertise, engage in discussions, and elevate collective knowledge across the community as part of the low-code revolution. Reflecting on the Impact As the challenge ends, it's essential to reflect on the impact it’s had across our Power Platform communities: Community Resilience: The challenge demonstrated the resilience of our community. Despite geographical distances and diverse backgrounds, we came together to contribute, learn, and collaborate. This resilience is the cornerstone of our collective strength.Diverse Expertise: The solutions shared during the challenge underscore the incredible expertise within our community. From intricate technical insights to creative problem-solving, our members showcased their diverse skill sets, enhancing our community's depth.Shared Learning: Solutions spurred shared learning. They provided opportunities for members to grasp new concepts, expand their horizons, and uncover the Power Platform tools' untapped potential. This learning ripple effect will continue to shape our growth. Empowerment: Solutions empowered community members. They validated their knowledge, boosted their confidence, and highlighted their contributions. Each solution shared was a step towards personal and communal empowerment. We are proud and thankful as we conclude the Summer of Solutions Challenge. The challenge showed the potential of teamwork, the benefit of knowledge-sharing, and the resilience of our Power Platform community. The solutions offered by each member are more than just answers; they are the expression of our shared commitment to innovation, growth, and progress! Drum roll, Please... And now, without further ado, it's time to announce the winners who have risen above the rest in the Summer of Solutions Challenge! These are the top community users and Super Users who have not only earned recognition but have become beacons of inspiration for us all. Power Apps Community: Community User Winner: @SpongYe Super User Winner: Pending Acceptance Power Automate Community: Community User Winner: @trice602 Super User Winner: @Expiscornovus Power Virtual Agents Community: Community User Winner: Pending AcceptanceSuper User: Pending Acceptance Power Pages Community: Community User Winner: @OOlashyn Super User Winner: @ChristianAbata We are also pleased to announced two additional tickets that we are awarding to the Overall Top Solution providers in the following communities: Power Apps: @LaurensM Power Automate: @ManishSolanki Thank you for making this challenge a resounding success. Your participation has reaffirmed the strength of our community and the boundless potential that lies within each of us. Let's keep the spirit of collaboration alive as we continue on this incredible journey in Power Platform together.Winners, we will see you in Vegas! Every other amazing solutions superstar, we will see you in the Community!Congratulations, everyone!