Фильтрация результатов во время запроса Algolia Search

Я работаю над личным Android-приложением на Kotlin, и я хочу реализовать InstantSearch. У меня есть следующая конструкция записи в Algolia:

{
  "creationTime": 1566396861797,
  "description": "It's my second home now...",
  "imagePath": "https://firebasestorage.googleapis.com/.......",
  "memoryId": "-LmoWe8PEqCs0Szv9KKJ",
  "memoryTitle": "Second visit",
  "userId": "vIWJgFpnUSeZJw3wjrJeEAxbNoE2",
  "imageLabels": [
    "Property",
    "Furniture",
    "City",
    "Human settlement",
    "Real estate",
    "Roof",
    "Room",
    "Skyline",
    "Building",
    "Metropolitan area",
    "Sky",
    "Balcony",
    "Apartment"
  ],
  "objectID": "-LmoWe8PEqCs0Szv9KKJ"
}

В моем InstantSearch я хочу обеспечить поиск, который представляет только записи со значением userId, идентичным этому конкретному пользователю, отправившему запрос. Сначала я добавил userId к атрибутам для фасетирования на панели инструментов. Я точно не знаю, как продолжить с этого момента. Я не знаю, как фильтровать записи во время запроса.

Вот моя ViewModel:

class MyViewModel : ViewModel() {
    val client = ClientSearch(ApplicationID("*****"), APIKey("*******"), LogLevel.ALL)
    val index = client.initIndex(IndexName("memory_diary"))
    val searcher = SearcherSingleIndex(index)
    val adapterMemory = MemoryAdapter()
    val dataSourceFactory = SearcherSingleIndexDataSource.Factory(searcher) { hit ->
        Memory(
                hit.json.getPrimitive("userId").content,
                hit.json.getPrimitive("objectID").content,
                hit.json.getPrimitive("memoryTitle").content,
                hit.json.getPrimitive("description").content,
                hit.json.getPrimitive("creationTime").content.toLong(),
                hit.json.getPrimitive("imagePath").content,
                hit.json.getArray("imageLabels").content.map { jsnelm -> jsnelm.content }
        )
    }


    val pagedListConfig = PagedList.Config.Builder().setPageSize(50).build()
    val memories: LiveData<PagedList<Memory>> = LivePagedListBuilder(dataSourceFactory, pagedListConfig).build()

    val searchBox = SearchBoxConnectorPagedList(searcher, listOf(memories))
    val stats = StatsConnector(searcher)
    val filterState = FilterState()
    val connection = ConnectionHandler()

    init {
        connection += searchBox
        connection += stats
        connection += filterState.connectPagedList(memories)
    }

    override fun onCleared() {
        super.onCleared()
        searcher.cancel()
        connection.disconnect()
    }
}

Я подумал, что, возможно, есть функция, которая фильтрует записи в SearcherSingleIndexDataSource.Factory, но я не нашел ничего подобного.

Так как я могу это сделать?


person Dvir Barzilay    schedule 28.08.2019    source источник
comment
Пожалуйста, не помечайте вопросы тегом android-studio только потому, что вы его используете: тег Android Studio следует использовать только, когда у вас есть вопросы о самой среде IDE, а не о любом коде, который вы пишете (или хочу написать) в нем. См. , когда целесообразно удалить тег IDE, Как избежать неправильного использования тегов? и руководство по тегам. Вместо этого используйте [android] или другие соответствующие теги.   -  person Zoe    schedule 29.08.2019


Ответы (2)


Чтобы узнать, как внедрять фильтры во время запроса, обратитесь к нашему Документация FilterState.

В вашем случае вы могли бы написать что-то вроде этого:

    filterState.notify {
       add(FilterGroupID(), Filter.Facet(Attribute("userId"), "user_id_value"))
    }

Сообщите мне, если это решит вашу проблему.

person Quentin Litzler    schedule 12.09.2019

Я реализовал фильтр, не дожидаясь ввода пользователя, и он сработал.

Я следил за документами algolia, но пропустил некоторые части https://www.algolia.com/doc/guides/building-search-ui/getting-started/android/

Для состояния фильтра потребуется Атрибут: в вашем случае userId.

Определите оператор и фильтр

Searcher подключается к FilterState и применяет свои фильтры при каждом поиске.

connection += searcher.connectFilterState(filterState)

В резюме ваша модель просмотра выглядит так:

val filterState = FilterState()
val filterGroupID = FilterGroupID("myGroup", FilterOperator.And)
val userId = Attribute("userId")
val filterUserId =  Filter.Facet(userId, "your_user_id")
   
val connection = ConnectionHandler()
    
init {
   filterState.add(filterGroupID, owner)
   connection += searchBox

   connection += searcher.connectFilterState(filterState)
   connection += filterState.connectPagedList(memories)
}
person María Teresa    schedule 22.01.2021