Considering UX Services for your software? Sign up for our series ✉️

Mobile Filter UX Design Patterns & Best Practices

July 15, 2024
Written By:
Fanny Vassilatos
Ceara Crawshaw

While doing some research for this piece, I was barely surprised to see that the first page of results is exclusively about e-commerce search and filtering. Lots of results are from Dribbble and even Pinterest… And that’s even when I write “enterprise” in my query. Have I not been using the right word? Please enlighten me. You might blame my Google algorithm, but I’m an enterprise UX designer and have been googling enterprise UX stuff for years! Luckily, that’s why we’re here.

Our original Enterprise Filtering piece had a great impact, and a lot of the questions around it were about mobile use cases. Ask and you shall receive!

Distinguishing enterprise vs consumer for mobile filters

Different goals

There’s a lot to unpack here. First off, enterprise and consumer products have very different goals. In the context of filtering, consumer filters want you to buy. Regardless of what you search, they're incentivized (and do!) find ways to show you something even if there's no matches. It could be presented as "Did you mean [this search term] instead?" or "Similar to [search term]".

However, for enterprise search and filtering behaviour, "no results" is a valid thing to display. Users might even be hitting up those search and filter functions to validate their assumptions and expectations, or as a key method of keeping an eye on things in their workflow. A good example of this is when users set their filters to "assigned to me" and "hide done". Sound familiar? On that note, notice that filters in enterprise aren't necessarily always triggered by search terms either. They can be just another way to refine what you're pulling from the database by default.

Relationship to labels

Enterprise and consumer apps also deal differently with labels. Consumer apps get to create labels and standardize their length.

Enterprise, on the other hand, has to deal with unpredictable, user generated strings. (And an unpredictable amount of strings at that!)

Prioritizing filters

Enterprise also has to prioritize their content differently. Consumer apps get to curate which filters to display and in what order—again, optimized for shopping.

However, enterprise platforms have to show aaall the data points in modifiable orders. (If users reorder their table columns, ideally you’d want to reflect that in the filters as well.)

🔗 Check out our in depth article on UX patterns for data tables.

Things to consider when designing mobile filter UX

A lot of our reflection and discussion prompts for building desktop filters apply for mobile as well. Take a look here!

What are your users’ mobile use cases?

You should invest some time to research this before developing the mobile version of any enterprise feature. Enterprise tends to cater to incredibly specific workflows, and it’s very likely that the mobile version of it is even more specific.

For example, think of some kind of sales-y commerce system. Depending on their role, a user’s tasks when they’re sitting at their desk can vary greatly from what they need to update while they’re commuting between two meetings—maybe they just need to quickly update the status of an entry, or add a simple note.

Knowing these things about your users will feed directly into the definition of an appropriate mobile solution.

Are you building in-browser or native?

You should get familiar with your app’s environment very early on. For search and filter behaviour, that means taking inventory of which native pieces you’ll get to reuse. Will you be leveraging browser-specific elements or OS-wide stuff? Do you know if your users choose native Safari over the Chrome app? Are you optimizing for Android first? All of these decisions affect the visual experience of using your filters.

☝️ Did you know | Quick note about browsers on iOS
All browsers on iOS are basically skins on top of Safari’s rendering engine. So as long as your app is running smoothly on native Safari, chances are you’re good on other browsers as well. There’s a little fun fact for the next chat you have with your dev team.

How will you adapt fetching?

If you’re building search filters for mobile, chances are you’ve already got a parallel feature running on your desktop version. Going mobile might mean you want to re-evaluate your fetching mechanism: Something that performs well on a laptop might not work as well on a smartphone. How will it perform on patchy 3G networks compared to dedicated wifi or ethernet connections? Adapting may mean thinking of how to optimize performance.

Typical problems for mobile filters

What makes mobile filtering so hard? Filtering is hard on mobile because with such a tiny screen, there’s a lot of scrolling. You feel disoriented and worried that you might lose your original view.

It’s also hard to know that a filter is even applied. With so little real estate on a given page, it’s hard to keep the entirety of the context in sight.

Sometimes, targets are hard to hit with sausage fingers. Of course, there are standards of usability, but clearly, not everyone read the book.

We also get varying experiences whether we’re in a browser or in a native app. In-browser interactions often feel jerky because the browser UI might pop in and out of view depending on the direction you’re scrolling in. Native apps have much more control over how it feels to navigate around, but launching a brand new app is a costly team decision.

Layout & Positioning is key on mobile

When it comes to layout and positioning, the typical options are

animated gif showing a mobile ui where filters are accessed through an icon on the top left of the screen

A top drawer that expands down

Having filters live at the top of the page is pretty expected. The eye will inevitably scan over them. It’s also natural for them to even live inside the table header row.

A bottom drawer that expands up

With a bottom drawer you’d have to be sure it sticks on top of the content so it’s always visible. This is precisely what will make the filter button hard to miss; it’ll overlap on top of users’ precious data and it’s easier to reach with thumbs.

ui example of a mobile device where filters open up as a bottom drawer
ui example of a mobile device where filters open up as a side drawer

A sidebar type of overlay

Having filters move-in as a sidebar provides more room to keep relevant parts of the background visible. You get to keep the left-most content visible, which is typically the most recognizable part. This helps users maintain context and feel safe that their original page isn’t lost.

And with all of those you can go two different routes:

Full-screen form type of flow

Any of these positionings can lead to a full-page filtering experience. This way to do it gives a lot of room to open and close dropdowns, navigate around all the filters, before being satisfied and clicking ‘Apply’.

The full-screen way might be more useful for use cases where the user knows exactly what they’re looking for and tends to use multiple filters at one.

screenshot of Salesmate mobile UI where filtering is a full-screen experience
On mobile, Salesmate offers a full-screen filtering experience. A more immersive flow like this makes sense for advanced filters that allow for maximum precision.

Keep original page in view but grayed-out

No matter the positioning of the filters, you can also limit its size and style it in a way that it looks simply overlaid on top of the original content. Adding a subtle transparent overlay can help users recognize they’re in a temporary flow “on top” of the page.

This way can be beneficial for users who want to see the results refresh in real time so they get a sense of how the filters they choose are affecting the data.

Overall it’s important to help your users keep their bearings. Help them maintain context by still displaying a grayed-out portion of what’s underneath. Make sure to offer a quick opt-out by having the close button always visible, or by allowing them to tap the grayed-out area to click out.

How & When to fetch

The same fetching methods from our original piece apply here. Let’s look at them through the considerations of mobile behaviour.

Live-Filtering

🔴 Live-filtering means that the system pulls new results with every interaction done on the filters.

Selecting a single item from a checkbox list? Fetch. Moving a threshold slider by one pixel? Fetch. Changing your date range’s start date? Fetch.

We would typically not recommend this one because the whole screen gets refreshed at every click and you risk getting abruptly kicked out of the filter drawer.

Unless, that is, if you update in the background (keep the drawer open). This way you provide immediate feedback while preserving the user’s sense of place. But your data has to be clean so that fetching feels almost immediate.

animated gif of Google Fonts on mobile where filters fetch live results as soon as they are selected
Google went with a live filtering fetching method. As shown, results refresh as soon as any filter selection is modified.

Per-filter

🟡 In a per-filter scenario, refreshing happens as the dropdown gets closed. This one could work well because it requires less taps, but your performance has to be A1.

For that you’ll need to account for extra room for an “Apply” button in each dropdown. Or you can also make it so that clicking the dropdown again closes it up and triggers the refresh.

Determine what the trigger is for a multi select vs single select. For example, if you know only one value is selectable from a dropdown list, you can have it so that a single click selects the item, closes the dropdown AND triggers the refresh. Bam.

Batch filtering

🟢 Batch-filtering is when you fetch only once, at the very end of the user selection. This option makes the most sense for enterprise products on mobile.

This gives users dedicated time to think their selection through, scan all the options and hit the Apply hard with a super refined query.  Once users are done with their selection, they Apply to click out of the filter drawer and explicitly ask for results.

Again, this might not perfectly fit your users’ use cases. Batch-filtering makes it harder to be exploratory since you need to know what you’re looking for.

UX Patterns you can use

Here are some pattern tips & tricks to enhance mobile filtering in your enterprise product.

Progressive disclosure

For enterprise contexts, you’ll want to leverage expandable sections and dropdowns. If you just expose everything right from the start, your users will get scrolling vertigo and risk feeling overwhelmed.

On the Shelter Market website, all filters are collapsible and they display the selection in real time at the top of the sidebar. (P.S. Yes I know this is an e-commerce example, gotta do what ya gotta do)

There’s going to be a lot of clicking. Which is fine on mobile, because the targets are close to each other, only a few millimeters apart. And 21st century human fingers move fast on glass screens.

As much as we encourage nesting and hiding stuff behind taps, one exception has to be for the Apply button. Users shouldn’t have to scroll to get to it. It should remain sticky, at the top or bottom, always in view.

Be selective

You don’t need to display everything. If the content itself, say a table, already has a reduced number of columns displayed on your mobile version, you don’t have to reflect all the filters as well.

There’s going to be a lot of clicking. Which is fine on mobile, because the targets are close to each other, only a few millimeters apart. And 21st century human fingers move fast on glass screens.

As much as we encourage nesting and hiding stuff behind taps, one exception has to be for the Apply button. Users shouldn’t have to scroll to get to it. It should remain sticky, at the top or bottom, always in view.

Be selective

You don’t need to display everything. If the content itself, say a table, already has a reduced number of columns displayed on your mobile version, you don’t have to reflect all the filters as well.

Offer “quick filters”

Limit the number of dropdowns. If a filter has 2 or 3 standardized options, check if you couldn’t instead display it as a switcher/picker.

Similarly, if a filter’s options offer numerical ranges, consider building a slider in.

When the number of options is limited in a certain filter, it might be worth making it into a switcher, reducing the number of taps required to reach it. In this case, there are a limited region and they can fit in a horizontal element.
Consider utilizing sliders if it's suitable for the use case. If the range you're dealing with is high, the user may not be able to pinpoint the exact value they want with ease unless there are other interactive guardrails in place (like magnetizing to key values). In this example, the vertical space it saves is prioritized.

Accelerate selections

Offer a “Select All” whenever you can. By offering more ways to do a selection (for example, tapping “Select All” and deselecting specific items), you increase the chances of a speedy input.

Don’t be afraid of big target areas

Make your selectors easy to select for fingers

example of the Peloton app on tablet where filters are displayed in a central modal with big visual buttons
Peloton makes great use of real estate by using big button-like targets in two columns for their length options

Allow users to save presets

Offer your users the ability to save their selection as a preset, so they can quickly switch in and out of their preferred views.

Especially for batch-filtering scenarios. Some power-users make filtering an art, they know exactly the way they want to see their data, the way it’s sorted and everything. Your filtering feature should honour that. Hey if it helps them in their workflow, it should make your team happy too!

Embrace the OS

Make sure the native components are used as much as possible. Not everyone knows this (shhh…) but OSes come with dropdown lists. USE THEM! Don’t try to reinvent the wheel here. Just like you wouldn’t code a whole mobile keyboard to ensure your users can input stuff. It’s wasted front-end effort and besides, it’ll likely up your performance if you don’t have to render custom dropdown overlays that respond weirdly to other stuff happening on the page.

I mean… Even Google can’t do it.

The thing about these native components is that they’re simply the best version out there. They were made by the very people who built the OS, these components are optimized to the brim. Plus, as users, they’re the ones we’ve used most often. We know how they work, they’re optimized for hand positioning and gestures. You just can’t go wrong with native.

On the Google Fonts website, when those custom dropdowns are scrollable or the inputs are draggable, it quickly interferes with the browser’s scroll triggers, making for suboptimal interactions.

Wrapping up

First off, congrats on taking on the challenge of offering your users a way to access deeper functionality on your enterprise system while on-the-go. If this made it to your roadmap, surely lots of folks will be happy.

As you design and build, make sure you find all the little places where you can provide additional help. Adapting your inputs for touch targets, revisiting the way you fetch, taking advantage of native elements in your chosen mobile environment.

As always, the better you know your users and their usecases, the more intuitive the experience will feel for them.

We hope this will help you on your journey, and we’d love to see how your mobile enterprise filters are being used in the wild!

Great data-rich UX minus the mess

Our secret methodology for features that hinge on data.

Amazing design for data-rich features relies on:
- Clarifying the problem space
- Unveiling the mystery of the data
- Establishing great collaborations that will lead to better data quality
- Creating realistic designs that fully consider the data structure, limitations and capacities
- Solidifying rationale through a process of understanding

Our Data Mapping Workshop is a tried and tested approach to understanding the data deeply, so you can design better (and look like a total pro in the process).

Data Mapping Workshop

$499 USD
Learn More

Download our Table UX Audit Checklist

Do a mini UX audit on your table views & find your trouble spots with this free guide.

Available in a printable version (pdf).

Please fill in the form below and it will be in your inbox shortly after.
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.
letters

Want to dig deeper on flow diagrams?

Be the first to know about our upcoming release!

If you found this intro content useful and find yourself needing to express yourself more efficiently on your software team, this training is for you. Our new flowchart training includes real-life enterprise stories and examples for using flowcharts for UX. You’ll get tips on how to make your diagramming efforts successful, how to derive info for the flow charts, and how to get others to use and participate in the diagramming process.
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.
Contact Us

Intro to UX for Teams

Learn the foundation that P&P uses to think through all interaction patterns, including errors, success and warnings

55 min
$90 USD

Explore our UX/UI Services

Curious about the possibility of working with the P&P crew on your enterprise software project? Check out our services.

Our services

Join our newsletter

Bringing enterprise-grade UX resources into the world to help you think better and have more interesting conversations with your crew!

Newsletter sign up

Data Tables Checklist

This free checklist lets you double check your data tables for their UX quality and assess various aspects which make or break the data table experience for your users.

PDF
Free

Explore our UX/UI Services

Curious about the possibility of working with the P&P crew on your enterprise software project? Check out our services.

Our services

Join our newsletter

Bringing enterprise-grade UX resources into the world to help you think better and have more interesting conversations with your crew!

Newsletter sign up