The Advanced Filter allows for complex filter conditions to be entered across columns in a single type-ahead input, as well as within a hierarchical visual builder.
 Enabling Advanced Filter Copy Link  
The Advanced Filter is enabled by setting the property enableAdvancedFilter = true. By default, the Advanced Filter is displayed between the column headers and the grid rows, where the Floating Filters would be displayed if they were enabled.
const gridOptions = {
    enableAdvancedFilter: true,
    // other grid options ...
}The following example demonstrates the Advanced Filter:
- Start typing athleteinto the Advanced Filter input. As you type, the list of suggested column names will be filtered down.
- Select the Athleteentry by pressing ↵ Enter or ⇥ Tab, or using the mouse to click on the entry.
- Select the containsentry in a similar way.
- After the quote, type michaelfollowed by an end quote (").
- Press ↵ Enter or click the Applybutton to execute the filter.
- The rows are now filtered to contain only Athletes with names containing michael.
- Try out each of the columns to see how the different Cell Data Types are handled.
- Complex filter expressions can be built up by using ANDandORalong with brackets -(and).
Advanced Filter and Column Filters cannot be active at the same time. Enabling Advanced Filter will disable Column Filters.
 Advanced Filter Builder Copy Link  
As well as typing into the Advanced Filter input, Advanced Filters can also be set by using the Advanced Filter Builder. This displays a hierarchical view of the filter, and allows the different filter parts to be set using dropdowns and inputs. It also allows for filter conditions to be added, deleted and reordered.
The Advanced Filter Builder can be launched by clicking the Builder button next to the Advanced Filter input.
The following example demonstrates the Advanced Filter Builder:
- Click on any of the dropdown pills to change the join operators, columns and filter options.
- Click on the value pills to change the filter values.
- Use the drag handles to move the filter conditions or groups around.
- Use the add and remove buttons to create new conditions or delete existing ones.
- If the filter is valid (and does not match the already applied filter), click the Applybutton to apply the filter.
 Configuring Columns Copy Link  
For a column to appear in the Advanced Filter, it needs to have filter: true (or set to a non-null and non-false value).
The type of the filter options displayed is based on the Cell Data Type of the column.
The different properties that can be set for each column are explained in the sections below, and demonstrated in the following example:
- The Age column is not available in the filter as filter = false.
- The Sport column is not available in the filter by default as hidden columns are excluded.
- After clicking Include Hidden Columns, the Sport column is available in the filter.
- The Group column does not appear in the filter, but its underlying column - Country - always appears.
- The Athlete column has Filter Params defined, so that it only shows the containsoption and is case sensitive.
- The Gold, Silver and Bronze columns in the Medals (-) column group have a headerValueGetterdefined and use thelocationproperty to have a different name in the filter (with a(-)suffix).
 Including Hidden Columns Copy Link  
By default, hidden columns do not appear in the Advanced Filter. To make hidden columns appear, set includeHiddenColumnsInAdvancedFilter = true.
| Hidden columns are excluded from the Advanced Filter by default.
To include hidden columns, set to  true. | 
 Row Grouping Copy Link  
When Row Grouping, group columns will not appear in the Advanced Filter. The underlying columns will always appear, even if hidden.
 Column Names Copy Link  
All column names that are enabled for filtering must be unique for the Advanced Filter to work correctly.
If columns have the same name by default (e.g. where they appear within different column groups), the name by which they appear in the Advanced Filter can be configured using a Header Value Getter and checking for location === 'advancedFilter'.
const gridOptions = {
    columnDefs: [
        {
            field: 'gold',
            headerValueGetter: params => params.location === 'advancedFilter' ? 'Gold 1' : 'Gold',
        },
        {
            field: 'gold',
            headerValueGetter: params => params.location === 'advancedFilter' ? 'Gold 2' : 'Gold',
        },
    ],
    // other grid options ...
} Filter Parameters Copy Link  
Certain properties can be set by using colDef.filterParams.
const gridOptions = {
    columnDefs: [
        {
            field: 'athlete',
            filterParams: {
                // perform case sensitive search
                caseSensitive: true,
                // limit options to `contains` only
                filterOptions: ['contains'],
            }
        }
    ],
    // other grid options ...
}For all Cell Data Types, the available filter options can be set via filterOptions.
The available options are as follows:
| Option Name | Option Key | Cell Data Type | 
|---|---|---|
| contains | contains | text,object | 
| does not contain | notContains | text,object | 
| equals | equals | text,object | 
| = | equals | number,date,dateString,dateTime,dateTimeString | 
| not equal | notEqual | text,object | 
| != | notEqual | number,date,dateString,dateTime,dateTimeString | 
| begins with | startsWith | text,object | 
| ends with | endsWith | text,object | 
| is blank | blank | text,number,boolean,date,dateString,dateTime,dateTimeString,object | 
| is not blank | notBlank | text,number,boolean,date,dateString,dateTime,dateTimeString,object | 
| > | greaterThan | number,date,dateString,dateTime,dateTimeString | 
| >= | greaterThanOrEqual | number,date,dateString,dateTime,dateTimeString | 
| < | lessThan | number,date,dateString,dateTime,dateTimeString | 
| <= | lessThanOrEqual | number,date,dateString,dateTime,dateTimeString | 
| is true | true | boolean | 
| is false | false | boolean | 
For text and object Cell Data Types, caseSensitive = true can be set to enable case sensitivity.
For number, date, dateString, dateTime and dateTimeString Cell Data Types, the following properties can be set to include blank values for the relevant options:
- includeBlanksInEquals = true
- includeBlanksInLessThan = true
- includeBlanksInGreaterThan = true
These settings only apply when using the Client-Side Row Model. You need to implement support for these in your server-side filtering logic when using the Server-Side Row Model.
 Filter Model / API Copy Link  
The Advanced Filter model describes the current state of the Advanced Filter. This is represented by an AdvancedFilterModel, which is either a ColumnAdvancedFilterModel for a single condition, or a JoinAdvancedFilterModel for multiple conditions:
| 'join' | 
|  How the conditions are joined together  | 
|  The filter conditions that are joined by the  type | 
For example, the Advanced Filter ([Age] > 23 OR [Sport] ends with "ing") AND [Country] contains "united" would be represented by the following model:
const advancedFilterModel = {
    filterType: 'join',
    type: 'AND',
    conditions: [
      {
        filterType: 'join',
        type: 'OR',
        conditions: [
          {
            filterType: 'number',
            colId: 'age',
            type: 'greaterThan',
            filter: 23,
          },
          {
            filterType: 'text',
            colId: 'sport',
            type: 'endsWith',
            filter: 'ing',
          }
        ]
      },
      {
        filterType: 'text',
        colId: 'country',
        type: 'contains',
        filter: 'united',
      }
    ]
};
The Advanced Filter Model can be retrieved via the API method getAdvancedFilterModel, and set via the API method setAdvancedFilterModel.
| Get the state of the Advanced Filter. Used for saving Advanced Filter state | 
| Set the state of the Advanced Filter. Used for restoring Advanced Filter state | 
The Advanced Filter Model can be saved and restored as part of Grid State.
The Advanced Filter Model and API methods are demonstrated in the following example:
- Clicking Save Advanced Filter Modelwill save the current Advanced Filter.
- Clicking Restore Advanced Filter Modelwill restore the previously saved Advanced Filter.
- Clicking Set Custom Advanced Filter Modelwill set[Gold] >= 1.
- Clicking Clear Advanced Filterwill clear the current Advanced Filter.
 Configuring Advanced Filter Copy Link  
It is possible to customise the buttons displayed in the Advanced Filter, allowing for the use of other Filter Buttons such as Reset, Cancel and Clear.
The Advanced Filter can be configured using the IAdvancedFilterParams interface:
|  Specifies the buttons to be shown in the Advanced Filter, in the order they should be displayed in.  The options are:  'apply': The Apply button will apply the filter.'clear': The Clear button will clear the filter input without removing the current active filter.'reset': The Reset button will clear the filter and apply an empty filter.'cancel': The Cancel button will discard any changes that have been made to the filter in the UI, restoring the applied model. | 
|  Whether to hide the Builder button to open the Advanced Filter Builder        | 
The params can be set via the grid option advancedFilterParams:
| Customise the parameters passed to the Advanced Filter | 
The following example demonstrates configuring the Advanced Filter:
- The Builderbutton has been removed, and the Advanced Filter Builder must now be opened via the API.
- The buttonshave been configured to add the Clear and Reset buttons.
 Advanced Filter Parent Copy Link  
By default the Advanced Filter is displayed underneath the Column Headers, where the Floating Filters would normally appear.
It is possible to instead display the Advanced Filter outside of the grid (such as above it). This can be done by setting the grid option advancedFilterParent and providing it with a DOM element to contain the filter.
| DOM element to use as the parent for the Advanced Filter to allow it to appear outside of the grid.
Set to  nullorundefinedto appear inside the grid. | 
The Popup Parent must also be set to an element that contains both the Advanced Filter parent and the grid.
The following example demonstrates displaying the Advanced Filter outside of the grid:
- The Advanced Filter parent is set using an element directly above the grid.
- Popup Parent is set to the document body.
 Configuring Advanced Filter Builder Copy Link  
The Advanced Filter Builder can be configured using the IAdvancedFilterBuilderParams interface:
|  Width in pixels of the Advanced Filter Builder add button select popup.        | 
|  Specifies the buttons to be shown in the Advanced Filter Builder, in the order they should be displayed in.  The options are:  'apply': The Apply button will apply the filter and close the builder.'clear': The Clear button will clear the filter in the builder without removing the current active filter.'reset': The Reset button will clear the filter and apply an empty filter.'cancel': The Cancel button will discard any changes that have been made to the filter in the UI, and close the Builder without applying any changes. | 
|  Minimum width in pixels of the Advanced Filter Builder popup.        | 
|  Max width in pixels of the Advanced Filter Builder pill select popup.        | 
|  Min width in pixels of the Advanced Filter Builder pill select popup.        | 
|  Whether to show the move up and move down buttons in the Advanced Filter Builder.        | 
|  Whether to hide the Full Screen button in the Advanced Filter Builder.        | 
The params can be set via the grid option advancedFilterBuilderParams:
| Customise the parameters passed to the Advanced Filter Builder. | 
As well as using the button in the Advanced Filter, it's possible to launch the Advanced Filter Builder via the showAdvancedFilterBuilder grid API method, and hide it via hideAdvancedFilterBuilder:
| Open the Advanced Filter Builder dialog (if enabled). | 
| Closes the Advanced Filter Builder dialog (if enabled).
Un-applied changes are discarded. | 
When the Advanced Filter Builder is shown or hidden, the advancedFilterBuilderVisibleChanged event is fired:
| Advanced Filter Builder visibility has changed (opened or closed). | 
The following example demonstrates configuring the Advanced Filter Builder:
- The Advanced Filter Builderbutton displays the Advanced Filter Builder via the API methodshowAdvancedFilterBuilder.
- The advancedFilterBuilderVisibleChangedevent is used to toggle the disabled status of theAdvanced Filter Builderbutton.
- The showMoveButtonsparam is set in theadvancedFilterBuilderParams, which displays buttons allowing the filter rows to be moved up and down (including via keyboard navigation).
 Cell Data Type Handling Copy Link  
All of the Cell Data Types are supported in the Advanced Filter. The behaviour of each is described below.
- Text - The value in the input is compared against the cell value before any Value Formatters are applied (similar to the Text Filter). To change the value being compared against, a Filter Value Getter can be used.
- Number - The value in the input is compared against the cell value (like in the Number Filter).
- Boolean - No values are displayed for booleans as the filter option is used instead.
- Date and Date Time - The value in the input is converted to a Datevia the Value Parser.
- Date String and Date Time String - The value in the input is converted to a Dateusing the Value Parser and the Date Parser. This is compared against the cell values, which are also converted using the Date Parser.
- Object - The value in the input is compared against the values returned by the Filter Value Getter if one is provided. Otherwise, the cell values are converted using the Value Formatter.
 Aggregation / Pivoting Copy Link  
The Advanced Filter will only work on leaf-level rows when using Aggregation. The groupAggFiltering property will be ignored.
When Pivoting, Pivot Result Columns will not appear in the Advanced Filter. However, primary columns (including underlying group and pivot columns) will be shown in the Advanced Filter.
 Server-Side Row Model Copy Link  
In addition to the Client-Side Row Model, the Advanced Filter can be used with the Server-Side Row Model. See the SSRM Advanced Filter Example for more information.
 Localisation Copy Link  
If providing custom Localisation values for the Advanced Filter, note that if the filter option values contain spaces, one option value cannot start with another option value.
 Next Up Copy Link  
Continue to the next section to learn about External Filters.