forked from github/wulkanowy-mirror
Add coroutines scope to presenter (#1554)
This commit is contained in:
parent
e02d93f979
commit
8e607d48f7
@ -6,29 +6,27 @@ import io.github.wulkanowy.utils.flowWithResource
|
||||
import kotlinx.coroutines.CoroutineScope
|
||||
import kotlinx.coroutines.Dispatchers
|
||||
import kotlinx.coroutines.Job
|
||||
import kotlinx.coroutines.SupervisorJob
|
||||
import kotlinx.coroutines.cancelChildren
|
||||
import kotlinx.coroutines.flow.Flow
|
||||
import kotlinx.coroutines.flow.catch
|
||||
import kotlinx.coroutines.flow.launchIn
|
||||
import kotlinx.coroutines.flow.onEach
|
||||
import timber.log.Timber
|
||||
import kotlin.coroutines.CoroutineContext
|
||||
|
||||
open class BasePresenter<T : BaseView>(
|
||||
protected val errorHandler: ErrorHandler,
|
||||
protected val studentRepository: StudentRepository
|
||||
) : CoroutineScope {
|
||||
) {
|
||||
private val job = SupervisorJob()
|
||||
|
||||
private var job = Job()
|
||||
protected val presenterScope = CoroutineScope(job + Dispatchers.Main)
|
||||
|
||||
private val jobs = mutableMapOf<String, Job>()
|
||||
|
||||
override val coroutineContext: CoroutineContext
|
||||
get() = Dispatchers.Main + job
|
||||
private val childrenJobs = mutableMapOf<String, Job>()
|
||||
|
||||
var view: T? = null
|
||||
|
||||
open fun onAttachView(view: T) {
|
||||
job = Job()
|
||||
this.view = view
|
||||
errorHandler.apply {
|
||||
showErrorMessage = view::showError
|
||||
@ -64,22 +62,22 @@ open class BasePresenter<T : BaseView>(
|
||||
}
|
||||
|
||||
fun <T> Flow<T>.launch(individualJobTag: String = "load"): Job {
|
||||
jobs[individualJobTag]?.cancel()
|
||||
val job = catch { errorHandler.dispatch(it) }.launchIn(this@BasePresenter)
|
||||
jobs[individualJobTag] = job
|
||||
childrenJobs[individualJobTag]?.cancel()
|
||||
val job = catch { errorHandler.dispatch(it) }.launchIn(presenterScope)
|
||||
childrenJobs[individualJobTag] = job
|
||||
Timber.d("Job $individualJobTag launched in ${this@BasePresenter.javaClass.simpleName}: $job")
|
||||
return job
|
||||
}
|
||||
|
||||
fun cancelJobs(vararg names: String) {
|
||||
names.forEach {
|
||||
jobs[it]?.cancel()
|
||||
childrenJobs[it]?.cancel()
|
||||
}
|
||||
}
|
||||
|
||||
open fun onDetachView() {
|
||||
view = null
|
||||
job.cancel()
|
||||
job.cancelChildren()
|
||||
errorHandler.clear()
|
||||
view = null
|
||||
}
|
||||
}
|
||||
|
@ -149,7 +149,7 @@ class DashboardPresenter @Inject constructor(
|
||||
tileList: List<DashboardItem.Type>,
|
||||
forceRefresh: Boolean
|
||||
) {
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
Timber.i("Loading dashboard account data started")
|
||||
val student = runCatching { studentRepository.getCurrentStudent(true) }
|
||||
.onFailure {
|
||||
|
@ -88,7 +88,7 @@ class NotificationDebugPresenter @Inject constructor(
|
||||
}
|
||||
|
||||
private fun withStudent(block: suspend (Student) -> Unit) {
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
block(studentRepository.getCurrentStudent(false))
|
||||
}
|
||||
}
|
||||
|
@ -15,7 +15,7 @@ class MessagePresenter @Inject constructor(
|
||||
|
||||
override fun onAttachView(view: MessageView) {
|
||||
super.onAttachView(view)
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
delay(150)
|
||||
view.initView()
|
||||
Timber.i("Message view was initialized")
|
||||
|
@ -224,14 +224,14 @@ class SendMessagePresenter @Inject constructor(
|
||||
}
|
||||
|
||||
fun onMessageContentChange() {
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
messageUpdateChannel.send(Unit)
|
||||
}
|
||||
}
|
||||
|
||||
@OptIn(FlowPreview::class)
|
||||
private fun initializeSubjectStream() {
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
messageUpdateChannel.consumeAsFlow()
|
||||
.debounce(250)
|
||||
.catch { Timber.e(it) }
|
||||
|
@ -173,14 +173,14 @@ class MessageTabPresenter @Inject constructor(
|
||||
}
|
||||
|
||||
fun onSearchQueryTextChange(query: String) {
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
searchChannel.send(query)
|
||||
}
|
||||
}
|
||||
|
||||
@OptIn(FlowPreview::class)
|
||||
private fun initializeSearchStream() {
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
searchChannel.consumeAsFlow()
|
||||
.debounce(250)
|
||||
.map { query ->
|
||||
|
@ -11,7 +11,6 @@ import io.github.wulkanowy.utils.AnalyticsHelper
|
||||
import io.github.wulkanowy.utils.afterLoading
|
||||
import io.github.wulkanowy.utils.flowWithResource
|
||||
import io.github.wulkanowy.utils.flowWithResourceIn
|
||||
import kotlinx.coroutines.flow.launchIn
|
||||
import kotlinx.coroutines.flow.onEach
|
||||
import timber.log.Timber
|
||||
import javax.inject.Inject
|
||||
@ -148,6 +147,6 @@ class MobileDevicePresenter @Inject constructor(
|
||||
errorHandler.dispatch(it.error!!)
|
||||
}
|
||||
}
|
||||
}.launchIn(this)
|
||||
}.launch("unregister")
|
||||
}
|
||||
}
|
||||
|
@ -11,7 +11,6 @@ import io.github.wulkanowy.utils.AnalyticsHelper
|
||||
import io.github.wulkanowy.utils.afterLoading
|
||||
import io.github.wulkanowy.utils.flowWithResource
|
||||
import io.github.wulkanowy.utils.flowWithResourceIn
|
||||
import kotlinx.coroutines.flow.launchIn
|
||||
import kotlinx.coroutines.flow.onEach
|
||||
import timber.log.Timber
|
||||
import javax.inject.Inject
|
||||
@ -123,7 +122,8 @@ class NotePresenter @Inject constructor(
|
||||
}
|
||||
|
||||
private fun updateNote(note: Note) {
|
||||
flowWithResource { noteRepository.updateNote(note) }.onEach {
|
||||
flowWithResource { noteRepository.updateNote(note) }
|
||||
.onEach {
|
||||
when (it.status) {
|
||||
Status.LOADING -> Timber.i("Attempt to update note ${note.id}")
|
||||
Status.SUCCESS -> Timber.i("Update note result: Success")
|
||||
@ -132,6 +132,7 @@ class NotePresenter @Inject constructor(
|
||||
errorHandler.dispatch(it.error!!)
|
||||
}
|
||||
}
|
||||
}.launchIn(this)
|
||||
}
|
||||
.launch("update_note")
|
||||
}
|
||||
}
|
||||
|
@ -15,7 +15,7 @@ class SchoolAndTeachersPresenter @Inject constructor(
|
||||
|
||||
override fun onAttachView(view: SchoolAndTeachersView) {
|
||||
super.onAttachView(view)
|
||||
launch {
|
||||
presenterScope.launch {
|
||||
delay(150)
|
||||
view.initView()
|
||||
Timber.i("Message view was initialized")
|
||||
|
Loading…
x
Reference in New Issue
Block a user