Pixelcat-App-Android/app/src/main/kotlin/at/connyduck/pixelcat/components/timeline/TimelineRemoteMediator.kt

57 lines
2.0 KiB
Kotlin
Raw Normal View History

2020-06-12 15:44:45 +02:00
package at.connyduck.pixelcat.components.timeline
import android.util.Log
import androidx.paging.ExperimentalPagingApi
import androidx.paging.LoadType
import androidx.paging.PagingState
import androidx.paging.RemoteMediator
import androidx.room.withTransaction
import at.connyduck.pixelcat.db.AppDatabase
import at.connyduck.pixelcat.db.entitity.StatusEntity
import at.connyduck.pixelcat.db.entitity.toEntity
import at.connyduck.pixelcat.network.FediverseApi
@ExperimentalPagingApi
class TimelineRemoteMediator(
private val accountId: Long,
private val api: FediverseApi,
private val db: AppDatabase
2020-06-12 19:58:15 +02:00
) : RemoteMediator<Int, StatusEntity>() {
2020-06-12 15:44:45 +02:00
override suspend fun load(
loadType: LoadType,
state: PagingState<Int, StatusEntity>
): MediatorResult {
val apiCall = when (loadType) {
LoadType.REFRESH -> {
api.homeTimeline(limit = state.config.initialLoadSize)
}
LoadType.PREPEND -> {
return MediatorResult.Success(true)
}
LoadType.APPEND -> {
val maxId = state.pages.findLast { it.data.isNotEmpty() }?.data?.lastOrNull()?.id
Log.w("TimelineRemoteMediator", "anchorPosition: ${state.anchorPosition} maxId: $maxId")
api.homeTimeline(maxId = maxId, limit = state.config.pageSize)
}
}
2020-06-12 19:58:15 +02:00
return apiCall.fold(
{ statusResult ->
2020-06-12 15:44:45 +02:00
db.withTransaction {
if (loadType == LoadType.REFRESH) {
db.statusDao().clearAll(accountId)
}
db.statusDao().insertOrReplace(statusResult.map { it.toEntity(accountId) })
}
2020-06-12 19:58:15 +02:00
MediatorResult.Success(endOfPaginationReached = statusResult.isEmpty())
},
{
MediatorResult.Error(it)
}
)
2020-06-12 15:44:45 +02:00
}
override suspend fun initialize() = InitializeAction.SKIP_INITIAL_REFRESH
2020-06-12 19:58:15 +02:00
}