|
|
@ -4,7 +4,6 @@ import android.util.Log |
|
|
|
import androidx.lifecycle.LiveData |
|
|
|
import androidx.lifecycle.LiveData |
|
|
|
import androidx.lifecycle.MutableLiveData |
|
|
|
import androidx.lifecycle.MutableLiveData |
|
|
|
import androidx.lifecycle.Transformations |
|
|
|
import androidx.lifecycle.Transformations |
|
|
|
import androidx.lifecycle.ViewModel |
|
|
|
|
|
|
|
import androidx.paging.PagedList |
|
|
|
import androidx.paging.PagedList |
|
|
|
import com.keylesspalace.tusky.components.search.adapter.SearchRepository |
|
|
|
import com.keylesspalace.tusky.components.search.adapter.SearchRepository |
|
|
|
import com.keylesspalace.tusky.db.AccountEntity |
|
|
|
import com.keylesspalace.tusky.db.AccountEntity |
|
|
@ -14,18 +13,17 @@ import com.keylesspalace.tusky.network.MastodonApi |
|
|
|
import com.keylesspalace.tusky.network.TimelineCases |
|
|
|
import com.keylesspalace.tusky.network.TimelineCases |
|
|
|
import com.keylesspalace.tusky.util.Listing |
|
|
|
import com.keylesspalace.tusky.util.Listing |
|
|
|
import com.keylesspalace.tusky.util.NetworkState |
|
|
|
import com.keylesspalace.tusky.util.NetworkState |
|
|
|
|
|
|
|
import com.keylesspalace.tusky.util.RxAwareViewModel |
|
|
|
import com.keylesspalace.tusky.util.ViewDataUtils |
|
|
|
import com.keylesspalace.tusky.util.ViewDataUtils |
|
|
|
import com.keylesspalace.tusky.viewdata.StatusViewData |
|
|
|
import com.keylesspalace.tusky.viewdata.StatusViewData |
|
|
|
import io.reactivex.Single |
|
|
|
import io.reactivex.Single |
|
|
|
import io.reactivex.android.schedulers.AndroidSchedulers |
|
|
|
import io.reactivex.android.schedulers.AndroidSchedulers |
|
|
|
import io.reactivex.disposables.CompositeDisposable |
|
|
|
|
|
|
|
import io.reactivex.rxkotlin.addTo |
|
|
|
|
|
|
|
import javax.inject.Inject |
|
|
|
import javax.inject.Inject |
|
|
|
|
|
|
|
|
|
|
|
class SearchViewModel @Inject constructor( |
|
|
|
class SearchViewModel @Inject constructor( |
|
|
|
mastodonApi: MastodonApi, |
|
|
|
mastodonApi: MastodonApi, |
|
|
|
private val timelineCases: TimelineCases, |
|
|
|
private val timelineCases: TimelineCases, |
|
|
|
private val accountManager: AccountManager) : ViewModel() { |
|
|
|
private val accountManager: AccountManager) : RxAwareViewModel() { |
|
|
|
|
|
|
|
|
|
|
|
var currentQuery: String = "" |
|
|
|
var currentQuery: String = "" |
|
|
|
|
|
|
|
|
|
|
@ -37,7 +35,6 @@ class SearchViewModel @Inject constructor( |
|
|
|
|
|
|
|
|
|
|
|
val mediaPreviewEnabled: Boolean |
|
|
|
val mediaPreviewEnabled: Boolean |
|
|
|
get() = activeAccount?.mediaPreviewEnabled ?: false |
|
|
|
get() = activeAccount?.mediaPreviewEnabled ?: false |
|
|
|
private val disposables = CompositeDisposable() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private val statusesRepository = SearchRepository<Pair<Status, StatusViewData.Concrete>>(mastodonApi) |
|
|
|
private val statusesRepository = SearchRepository<Pair<Status, StatusViewData.Concrete>>(mastodonApi) |
|
|
|
private val accountsRepository = SearchRepository<Account>(mastodonApi) |
|
|
|
private val accountsRepository = SearchRepository<Account>(mastodonApi) |
|
|
@ -83,11 +80,6 @@ class SearchViewModel @Inject constructor( |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
override fun onCleared() { |
|
|
|
|
|
|
|
super.onCleared() |
|
|
|
|
|
|
|
disposables.clear() |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun removeItem(status: Pair<Status, StatusViewData.Concrete>) { |
|
|
|
fun removeItem(status: Pair<Status, StatusViewData.Concrete>) { |
|
|
|
timelineCases.delete(status.first.id) |
|
|
|
timelineCases.delete(status.first.id) |
|
|
|
.subscribe({ |
|
|
|
.subscribe({ |
|
|
@ -96,7 +88,7 @@ class SearchViewModel @Inject constructor( |
|
|
|
}, { |
|
|
|
}, { |
|
|
|
err -> Log.d(TAG, "Failed to delete status", err) |
|
|
|
err -> Log.d(TAG, "Failed to delete status", err) |
|
|
|
}) |
|
|
|
}) |
|
|
|
.addTo(disposables) |
|
|
|
.autoDispose() |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -110,13 +102,13 @@ class SearchViewModel @Inject constructor( |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fun reblog(status: Pair<Status, StatusViewData.Concrete>, reblog: Boolean) { |
|
|
|
fun reblog(status: Pair<Status, StatusViewData.Concrete>, reblog: Boolean) { |
|
|
|
disposables.add(timelineCases.reblog(status.first, reblog) |
|
|
|
timelineCases.reblog(status.first, reblog) |
|
|
|
.observeOn(AndroidSchedulers.mainThread()) |
|
|
|
.observeOn(AndroidSchedulers.mainThread()) |
|
|
|
.subscribe( |
|
|
|
.subscribe( |
|
|
|
{ setRebloggedForStatus(status, reblog) }, |
|
|
|
{ setRebloggedForStatus(status, reblog) }, |
|
|
|
{ err -> Log.d(TAG, "Failed to reblog status ${status.first.id}", err) } |
|
|
|
{ err -> Log.d(TAG, "Failed to reblog status ${status.first.id}", err) } |
|
|
|
) |
|
|
|
) |
|
|
|
) |
|
|
|
.autoDispose() |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private fun setRebloggedForStatus(status: Pair<Status, StatusViewData.Concrete>, reblog: Boolean) { |
|
|
|
private fun setRebloggedForStatus(status: Pair<Status, StatusViewData.Concrete>, reblog: Boolean) { |
|
|
@ -152,7 +144,7 @@ class SearchViewModel @Inject constructor( |
|
|
|
fun voteInPoll(status: Pair<Status, StatusViewData.Concrete>, choices: MutableList<Int>) { |
|
|
|
fun voteInPoll(status: Pair<Status, StatusViewData.Concrete>, choices: MutableList<Int>) { |
|
|
|
val votedPoll = status.first.actionableStatus.poll!!.votedCopy(choices) |
|
|
|
val votedPoll = status.first.actionableStatus.poll!!.votedCopy(choices) |
|
|
|
updateStatus(status, votedPoll) |
|
|
|
updateStatus(status, votedPoll) |
|
|
|
disposables.add(timelineCases.voteInPoll(status.first, choices) |
|
|
|
timelineCases.voteInPoll(status.first, choices) |
|
|
|
.observeOn(AndroidSchedulers.mainThread()) |
|
|
|
.observeOn(AndroidSchedulers.mainThread()) |
|
|
|
.subscribe( |
|
|
|
.subscribe( |
|
|
|
{ newPoll -> updateStatus(status, newPoll) }, |
|
|
|
{ newPoll -> updateStatus(status, newPoll) }, |
|
|
@ -160,7 +152,8 @@ class SearchViewModel @Inject constructor( |
|
|
|
Log.d(TAG, |
|
|
|
Log.d(TAG, |
|
|
|
"Failed to vote in poll: ${status.first.id}", t) |
|
|
|
"Failed to vote in poll: ${status.first.id}", t) |
|
|
|
} |
|
|
|
} |
|
|
|
)) |
|
|
|
) |
|
|
|
|
|
|
|
.autoDispose() |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private fun updateStatus(status: Pair<Status, StatusViewData.Concrete>, newPoll: Poll) { |
|
|
|
private fun updateStatus(status: Pair<Status, StatusViewData.Concrete>, newPoll: Poll) { |
|
|
@ -182,9 +175,10 @@ class SearchViewModel @Inject constructor( |
|
|
|
loadedStatuses[idx] = newPair |
|
|
|
loadedStatuses[idx] = newPair |
|
|
|
repoResultStatus.value?.refresh?.invoke() |
|
|
|
repoResultStatus.value?.refresh?.invoke() |
|
|
|
} |
|
|
|
} |
|
|
|
disposables.add(timelineCases.favourite(status.first, isFavorited) |
|
|
|
timelineCases.favourite(status.first, isFavorited) |
|
|
|
.onErrorReturnItem(status.first) |
|
|
|
.onErrorReturnItem(status.first) |
|
|
|
.subscribe()) |
|
|
|
.subscribe() |
|
|
|
|
|
|
|
.autoDispose() |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fun bookmark(status: Pair<Status, StatusViewData.Concrete>, isBookmarked: Boolean) { |
|
|
|
fun bookmark(status: Pair<Status, StatusViewData.Concrete>, isBookmarked: Boolean) { |
|
|
@ -194,9 +188,10 @@ class SearchViewModel @Inject constructor( |
|
|
|
loadedStatuses[idx] = newPair |
|
|
|
loadedStatuses[idx] = newPair |
|
|
|
repoResultStatus.value?.refresh?.invoke() |
|
|
|
repoResultStatus.value?.refresh?.invoke() |
|
|
|
} |
|
|
|
} |
|
|
|
disposables.add(timelineCases.favourite(status.first, isBookmarked) |
|
|
|
timelineCases.favourite(status.first, isBookmarked) |
|
|
|
.onErrorReturnItem(status.first) |
|
|
|
.onErrorReturnItem(status.first) |
|
|
|
.subscribe()) |
|
|
|
.subscribe() |
|
|
|
|
|
|
|
.autoDispose() |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fun getAllAccountsOrderedByActive(): List<AccountEntity> { |
|
|
|
fun getAllAccountsOrderedByActive(): List<AccountEntity> { |
|
|
|