mirror of
https://github.com/element-hq/element-android
synced 2024-11-24 02:15:35 +03:00
Init room in constructor.
This commit is contained in:
parent
4dbeaeb465
commit
d4a0659483
1 changed files with 17 additions and 12 deletions
|
@ -29,6 +29,7 @@ import im.vector.app.core.extensions.exhaustive
|
|||
import im.vector.app.core.platform.VectorViewModel
|
||||
import kotlinx.coroutines.launch
|
||||
import org.matrix.android.sdk.api.session.Session
|
||||
import org.matrix.android.sdk.api.session.room.Room
|
||||
import org.matrix.android.sdk.api.session.search.SearchResult
|
||||
import org.matrix.android.sdk.internal.util.awaitCallback
|
||||
|
||||
|
@ -37,6 +38,12 @@ class SearchViewModel @AssistedInject constructor(
|
|||
private val session: Session
|
||||
) : VectorViewModel<SearchViewState, SearchAction, SearchViewEvents>(initialState) {
|
||||
|
||||
private var room: Room? = null
|
||||
|
||||
init {
|
||||
room = initialState.roomId?.let { session.getRoom(it) }
|
||||
}
|
||||
|
||||
@AssistedInject.Factory
|
||||
interface Factory {
|
||||
fun create(initialState: SearchViewState): SearchViewModel
|
||||
|
@ -94,18 +101,16 @@ class SearchViewModel @AssistedInject constructor(
|
|||
viewModelScope.launch {
|
||||
try {
|
||||
val result = awaitCallback<SearchResult> {
|
||||
session
|
||||
.getRoom(state.roomId)
|
||||
?.search(
|
||||
searchTerm = state.searchTerm,
|
||||
nextBatch = state.searchResult?.nextBatch,
|
||||
orderByRecent = true,
|
||||
beforeLimit = 0,
|
||||
afterLimit = 0,
|
||||
includeProfile = true,
|
||||
limit = 20,
|
||||
callback = it
|
||||
)
|
||||
room?.search(
|
||||
searchTerm = state.searchTerm,
|
||||
nextBatch = state.searchResult?.nextBatch,
|
||||
orderByRecent = true,
|
||||
beforeLimit = 0,
|
||||
afterLimit = 0,
|
||||
includeProfile = true,
|
||||
limit = 20,
|
||||
callback = it
|
||||
)
|
||||
}
|
||||
onSearchResultSuccess(result, isNextBatch)
|
||||
} catch (failure: Throwable) {
|
||||
|
|
Loading…
Reference in a new issue