List Conditional Filters

Setting up conditions to filter the list data.

The conditional filtering feature allows you to filter the list, as well as other dynamic blocks, based on the defined conditions. It's available through Conditional Filters in the block settings sidebar under the Source section.

Notion image

Now, let's see how it works.

First of all, from the dropdown selector at the top, you can choose whether any or all of the defined conditions should be met for filtering the information.

โ€œAnyโ€ or โ€œAllโ€ of the conditions
โ€œAnyโ€ or โ€œAllโ€ of the conditions

Additional conditions can be joined with:

  • AND (when "All" is selected)
  • OR (when "Any" is selected)
Notion image

Moving on, let's see how the Condition is configured. There are three fields in Condition Settings:

1. Field

Here, you need to select a field from the specified data source base, for which the condition will be defined.

2. Condition

Notion image

The following options are available for defining a relationship between the Field and the Value.

ย 

Text-like Fields, e.g. emails, formulas, URLs, single select fields โ€“ can be used with the following available conditions:

  • Is โ€“ the Field value needs to match the Value exactly
  • Is not โ€“ the Field value has any value apart from the Value
  • Contains โ€“ the Field value partially matches the Value
  • Does not contain - the Field value doesnโ€™t partially match the Value. It checks if the given Value is not present within the Field value
  • Is any of โ€“the Field value is any of the Value(s). Multiple values can be added
  • Is none of โ€“ the Field values have any other value apart from the Value(s). Multiple values can be added
  • Is empty โ€“ the Field value is empty
  • Is not empty โ€“ the Field value is not empty. Has some value
  • Starts with โ€“ the Field value starts with the Value
  • Ends with โ€“ the Field value ends with the Value
ย 

Numeric Fields can be used with the following available conditions:

  • =
  • โ‰ 
  • >
  • <
  • โ‰ฅ
  • โ‰ค
  • Is between (inclusive of min/max)
  • Is empty
  • Is not empty
ย 

Array-like Fields, e.g. multi-select fields, linked records, tags, lookup fields can be used with the following available conditions:

  • Includes any of
  • Includes all of
  • Includes exactly
  • Includes none of
  • Is empty
  • Is not empty
ย 

Boolean Fields, e.g. checkbox fields:

  • Is
  • Is not
  • Is empty
  • Is not empty
ย 
โ„น๏ธ
At the moment Date fields can be used with the same conditions as Text-like Fields.

3. Value

Here, you have two options. Let's consider each one separately.

Entering a specific value

You can enter a specific value for the selected field so that only the records having that value are displayed.

๐Ÿ’ก
If the value contains a space, you'd need to copy it from somewhere else instead of typing it in.

Let's say we have a list of employees in Airtable and want to display only the ones whose position is Project Manager.

A list of employees in Airtable
A list of employees in Airtable

Below you can see how we apply a conditional filter to show only the entries that meet this condition.

Applying a conditional filter to the list
Applying a conditional filter to the list

Using Logged-in user's parameters

Using this option, you can set a condition to filter the list for each logged-in user personally, so that each user only sees entries related to him/her.

By default, you'll have user's Email and Email-Domain options here. However, if you've connected users to a data source, all the fields from the data source will also become available for your choice. Below, you can see how we add fields from the connected Airtable table.

Fields added from the connected Airtable base
Fields added from the connected Airtable base

Let's consider a specific example to make it clear how this works and in which cases it can be applied. Let's imagine you have a task list on Airtable with such fields as Assignee, Description, and Status. The Assignee field contains the emails of the users to which the task is assigned.

Task list on Airtable
Task list on Airtable

To be able to view their tasks, the users need to log into the system and navigate to the page with the list. However, you want each user to see only his/her tasks, and that can be achieved with a single condition. In Condition Settings we are going to set the Field to Assignee and Action to Logged in User's Email. This way the logged in user will only see those entries of the list, where the Assignee field corresponds to his/her email address. The below GIF illustrates this.

Testing the conditional filter
Testing the conditional filter

That's it. This way, you can set a condition for any of the fields in your list and filter the list accordingly for your logged in users.

๐Ÿ’ก
More attributes will be added soon to allow for more advanced filtering based on additional user attributes such as user roles, statuses, and so on.

Now, letโ€™s consider some specific value use cases to see how you can handle them.

Use Case: Using a Checkbox field in a Conditional Filter

Airtable has a Checkbox field type which you might want to use in a conditional filter.

๐Ÿ’ก
The list block doesn't have a Checkbox field type (the Table block has it though), but you can still use it in a conditional filter (if you have it on Airtable) even without displaying it.

If you want to display the records that have the checkbox checked, you can use the is not empty condition as shown below. And vice versa, if you want to filter the unchecked records, you can use the is empty condition.

"is not empty" condition for showing checked items
"is not empty" condition for showing checked items

Security

๐Ÿ’ก
Softr viability checks and record conditional filters are applied on the server side, and there is no way to trick the system. Learn more about Softr App Security.
ย 
Did this answer your question?
๐Ÿ˜ž
๐Ÿ˜
๐Ÿคฉ

Last updated on March 27, 2024