Calling use case inside ViewModel
This commit is contained in:
parent
c6c46375d6
commit
b17ce12c3d
|
@ -269,8 +269,6 @@ class VectorAttachmentViewerActivity : AttachmentViewerActivity(), AttachmentInt
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO add save feature for image => check it works for video as well,
|
|
||||||
// check if it is already possible to save from menu with long press on video
|
|
||||||
override fun onDownload() {
|
override fun onDownload() {
|
||||||
// TODO
|
// TODO
|
||||||
// call usecase using viewModel into handle method
|
// call usecase using viewModel into handle method
|
||||||
|
@ -279,6 +277,8 @@ class VectorAttachmentViewerActivity : AttachmentViewerActivity(), AttachmentInt
|
||||||
// show message on error event: see TimelineFragment
|
// show message on error event: see TimelineFragment
|
||||||
// check write file permissions: see TimelineFragment
|
// check write file permissions: see TimelineFragment
|
||||||
// should we check if media is saveable?
|
// should we check if media is saveable?
|
||||||
|
// check if it is already possible to save from menu with long press on video
|
||||||
|
// check if it works for video or other media type as well
|
||||||
// add unit tests for usecase?
|
// add unit tests for usecase?
|
||||||
TODO("Not yet implemented")
|
TODO("Not yet implemented")
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,5 @@ import im.vector.app.core.platform.VectorViewEvents
|
||||||
|
|
||||||
sealed class VectorAttachmentViewerViewEvents : VectorViewEvents {
|
sealed class VectorAttachmentViewerViewEvents : VectorViewEvents {
|
||||||
object DownloadingMedia : VectorAttachmentViewerViewEvents()
|
object DownloadingMedia : VectorAttachmentViewerViewEvents()
|
||||||
object MediaDownloaded : VectorAttachmentViewerViewEvents()
|
|
||||||
object ErrorDownloadingMedia : VectorAttachmentViewerViewEvents()
|
object ErrorDownloadingMedia : VectorAttachmentViewerViewEvents()
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,9 +23,12 @@ import dagger.assisted.AssistedInject
|
||||||
import im.vector.app.core.di.MavericksAssistedViewModelFactory
|
import im.vector.app.core.di.MavericksAssistedViewModelFactory
|
||||||
import im.vector.app.core.platform.VectorDummyViewState
|
import im.vector.app.core.platform.VectorDummyViewState
|
||||||
import im.vector.app.core.platform.VectorViewModel
|
import im.vector.app.core.platform.VectorViewModel
|
||||||
|
import im.vector.app.features.media.domain.usecase.DownloadMediaUseCase
|
||||||
|
import kotlinx.coroutines.launch
|
||||||
|
|
||||||
class VectorAttachmentViewerViewModel @AssistedInject constructor(
|
class VectorAttachmentViewerViewModel @AssistedInject constructor(
|
||||||
@Assisted initialState: VectorDummyViewState
|
@Assisted initialState: VectorDummyViewState,
|
||||||
|
private val downloadMediaUseCase: DownloadMediaUseCase
|
||||||
) : VectorViewModel<VectorDummyViewState, VectorAttachmentViewerAction, VectorAttachmentViewerViewEvents>(initialState) {
|
) : VectorViewModel<VectorDummyViewState, VectorAttachmentViewerAction, VectorAttachmentViewerViewEvents>(initialState) {
|
||||||
|
|
||||||
/* ==========================================================================================
|
/* ==========================================================================================
|
||||||
|
@ -42,6 +45,22 @@ class VectorAttachmentViewerViewModel @AssistedInject constructor(
|
||||||
* ========================================================================================== */
|
* ========================================================================================== */
|
||||||
|
|
||||||
override fun handle(action: VectorAttachmentViewerAction) {
|
override fun handle(action: VectorAttachmentViewerAction) {
|
||||||
TODO("Not yet implemented")
|
when (action) {
|
||||||
|
is VectorAttachmentViewerAction.DownloadMedia -> handleDownloadAction(action)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ==========================================================================================
|
||||||
|
* Private methods
|
||||||
|
* ========================================================================================== */
|
||||||
|
|
||||||
|
private fun handleDownloadAction(action: VectorAttachmentViewerAction.DownloadMedia) {
|
||||||
|
viewModelScope.launch {
|
||||||
|
_viewEvents.post(VectorAttachmentViewerViewEvents.DownloadingMedia)
|
||||||
|
|
||||||
|
// Success event is handled via a notification inside use case
|
||||||
|
downloadMediaUseCase.execute(action.file)
|
||||||
|
.onFailure { _viewEvents.post(VectorAttachmentViewerViewEvents.ErrorDownloadingMedia) }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue