About this widget #
FilterList is a filtering view that displays any kind of filters, and lets the user refine the search results by selecting them.
Compared to the RefinementList, which takes its values from the search response facets, this widget displays filters that you add yourself.
To add a filter list to your search experience, use these components:
Searcher: TheSearcherthat handles your searches.FilterState: The current state of the filters.FilterListViewModel.All: The logic applied to the filters.FilterListView.All: The view that will render the filters.FilterPresenter: Optional. The presenter to customize the display of the filters.
Examples #
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
class MyActivity : AppCompatActivity() {
val client = ClientSearch(
ApplicationID("AJ0P3S7DWQ"),
APIKey("YourAPIKey")
)
val index = client.initIndex(IndexName("YourIndexName"))
val searcher = SearcherSingleIndex(index)
val filterState = FilterState()
val color = Attribute("color")
val price = Attribute("price")
val filters = listOf(
Filter.Numeric(price, 5..10),
Filter.Tag("coupon"),
Filter.Facet(color, "red"),
Filter.Facet(color, "black"),
Filter.Numeric(price, NumericOperator.Greater, 100)
)
val viewModel = FilterListViewModel.All(filters)
val connection = ConnectionHandler()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val view: FilterListView.All = MyFilterListRecyclerViewAdapter()
connection += searcher.connectFilterState(filterState)
connection += viewModel.connectFilterState(filterState)
connection += viewModel.connectView(view)
searcher.searchAsync()
}
override fun onDestroy() {
super.onDestroy()
connection.disconnect()
searcher.cancel()
}
}
Parameters #
searcher
# |
type: Searcher
Required
The |
||
|
|
|||
filterState
# |
type: FilterState
Required
The |
||
|
|
|||
filterListView
# |
type: FilterListView
Required
The view that will render the filters. |
||
|
|
|||
attribute
# |
type: Attribute
Required
The attribute to filter. |
||
|
Edit
Copy
|
|||
items
# |
type: List<Filter>
default: listOf()
Required
The filters to display. |
||
|
Edit
Copy
|
|||
groupId.operator
# |
type: FilterOperator
default: FilterOperator.And
Optional
Whether we apply an For example if we have an |
||
|
|
|||
selectionMode
# |
type: SelectionMode
default: Multiple
Optional
Whether the list can have |
||
|
|
|||
Presenter #
presenter
# |
type: FilterPresenter
default: FilterPresenterImpl()
Optional
A presenter describing how to display a filter. |
||
|
Edit
Copy
|
|||