mirror of
https://github.com/nextcloud/talk-android
synced 2025-07-14 08:15:04 +01:00
DI: Setup viewmodel injection
Signed-off-by: Álvaro Brey <alvaro.brey@nextcloud.com>
This commit is contained in:
parent
6716726ff1
commit
716dcfe01d
@ -9,10 +9,12 @@ import androidx.lifecycle.ViewModelProvider
|
|||||||
import androidx.recyclerview.widget.GridLayoutManager
|
import androidx.recyclerview.widget.GridLayoutManager
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
import androidx.recyclerview.widget.RecyclerView
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
|
import autodagger.AutoInjector
|
||||||
import com.google.android.material.tabs.TabLayout
|
import com.google.android.material.tabs.TabLayout
|
||||||
import com.nextcloud.talk.R
|
import com.nextcloud.talk.R
|
||||||
import com.nextcloud.talk.adapters.SharedItemsGridAdapter
|
import com.nextcloud.talk.adapters.SharedItemsGridAdapter
|
||||||
import com.nextcloud.talk.adapters.SharedItemsListAdapter
|
import com.nextcloud.talk.adapters.SharedItemsListAdapter
|
||||||
|
import com.nextcloud.talk.application.NextcloudTalkApplication
|
||||||
import com.nextcloud.talk.databinding.ActivitySharedItemsBinding
|
import com.nextcloud.talk.databinding.ActivitySharedItemsBinding
|
||||||
import com.nextcloud.talk.models.database.UserEntity
|
import com.nextcloud.talk.models.database.UserEntity
|
||||||
import com.nextcloud.talk.repositories.SharedItemType
|
import com.nextcloud.talk.repositories.SharedItemType
|
||||||
@ -21,14 +23,20 @@ import com.nextcloud.talk.utils.bundle.BundleKeys.KEY_CONVERSATION_NAME
|
|||||||
import com.nextcloud.talk.utils.bundle.BundleKeys.KEY_ROOM_TOKEN
|
import com.nextcloud.talk.utils.bundle.BundleKeys.KEY_ROOM_TOKEN
|
||||||
import com.nextcloud.talk.utils.bundle.BundleKeys.KEY_USER_ENTITY
|
import com.nextcloud.talk.utils.bundle.BundleKeys.KEY_USER_ENTITY
|
||||||
import com.nextcloud.talk.viewmodels.SharedItemsViewModel
|
import com.nextcloud.talk.viewmodels.SharedItemsViewModel
|
||||||
|
import javax.inject.Inject
|
||||||
|
|
||||||
|
@AutoInjector(NextcloudTalkApplication::class)
|
||||||
class SharedItemsActivity : AppCompatActivity() {
|
class SharedItemsActivity : AppCompatActivity() {
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
lateinit var viewModelFactory: ViewModelProvider.Factory
|
||||||
|
|
||||||
private lateinit var binding: ActivitySharedItemsBinding
|
private lateinit var binding: ActivitySharedItemsBinding
|
||||||
private lateinit var viewModel: SharedItemsViewModel
|
private lateinit var viewModel: SharedItemsViewModel
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
|
NextcloudTalkApplication.sharedApplication!!.componentApplication.inject(this)
|
||||||
|
|
||||||
val roomToken = intent.getStringExtra(KEY_ROOM_TOKEN)!!
|
val roomToken = intent.getStringExtra(KEY_ROOM_TOKEN)!!
|
||||||
val conversationName = intent.getStringExtra(KEY_CONVERSATION_NAME)
|
val conversationName = intent.getStringExtra(KEY_CONVERSATION_NAME)
|
||||||
@ -52,10 +60,8 @@ class SharedItemsActivity : AppCompatActivity() {
|
|||||||
supportActionBar?.title = conversationName
|
supportActionBar?.title = conversationName
|
||||||
supportActionBar?.setDisplayHomeAsUpEnabled(true)
|
supportActionBar?.setDisplayHomeAsUpEnabled(true)
|
||||||
|
|
||||||
viewModel = ViewModelProvider(
|
viewModel = ViewModelProvider(this, viewModelFactory)[SharedItemsViewModel::class.java]
|
||||||
this,
|
viewModel.initialize(userEntity, roomToken, SharedItemType.MEDIA)
|
||||||
SharedItemsViewModel.Factory(userEntity, roomToken, SharedItemType.MEDIA)
|
|
||||||
).get(SharedItemsViewModel::class.java)
|
|
||||||
|
|
||||||
viewModel.sharedItemTypes.observe(this) {
|
viewModel.sharedItemTypes.observe(this) {
|
||||||
initTabs(it)
|
initTabs(it)
|
||||||
|
@ -55,7 +55,9 @@ import com.nextcloud.talk.components.filebrowser.webdav.DavUtils
|
|||||||
import com.nextcloud.talk.dagger.modules.BusModule
|
import com.nextcloud.talk.dagger.modules.BusModule
|
||||||
import com.nextcloud.talk.dagger.modules.ContextModule
|
import com.nextcloud.talk.dagger.modules.ContextModule
|
||||||
import com.nextcloud.talk.dagger.modules.DatabaseModule
|
import com.nextcloud.talk.dagger.modules.DatabaseModule
|
||||||
|
import com.nextcloud.talk.dagger.modules.RepositoryModule
|
||||||
import com.nextcloud.talk.dagger.modules.RestModule
|
import com.nextcloud.talk.dagger.modules.RestModule
|
||||||
|
import com.nextcloud.talk.dagger.modules.ViewModelModule
|
||||||
import com.nextcloud.talk.jobs.AccountRemovalWorker
|
import com.nextcloud.talk.jobs.AccountRemovalWorker
|
||||||
import com.nextcloud.talk.jobs.CapabilitiesWorker
|
import com.nextcloud.talk.jobs.CapabilitiesWorker
|
||||||
import com.nextcloud.talk.jobs.SignalingSettingsWorker
|
import com.nextcloud.talk.jobs.SignalingSettingsWorker
|
||||||
@ -89,7 +91,9 @@ import javax.inject.Singleton
|
|||||||
DatabaseModule::class,
|
DatabaseModule::class,
|
||||||
RestModule::class,
|
RestModule::class,
|
||||||
UserModule::class,
|
UserModule::class,
|
||||||
ArbitraryStorageModule::class
|
ArbitraryStorageModule::class,
|
||||||
|
ViewModelModule::class,
|
||||||
|
RepositoryModule::class
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
@Singleton
|
@Singleton
|
||||||
|
@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* Nextcloud Talk application
|
||||||
|
*
|
||||||
|
* @author Álvaro Brey
|
||||||
|
* Copyright (C) 2022 Álvaro Brey
|
||||||
|
* Copyright (C) 2022 Nextcloud GmbH
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.nextcloud.talk.dagger.modules
|
||||||
|
|
||||||
|
import com.nextcloud.talk.api.NcApi
|
||||||
|
import com.nextcloud.talk.repositories.SharedItemsRepository
|
||||||
|
import dagger.Module
|
||||||
|
import dagger.Provides
|
||||||
|
|
||||||
|
@Module
|
||||||
|
class RepositoryModule {
|
||||||
|
@Provides
|
||||||
|
fun provideSharedItemsRepository(ncApi: NcApi): SharedItemsRepository {
|
||||||
|
return SharedItemsRepository(ncApi)
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,56 @@
|
|||||||
|
/*
|
||||||
|
* Nextcloud Talk application
|
||||||
|
*
|
||||||
|
* @author Álvaro Brey
|
||||||
|
* Copyright (C) 2022 Álvaro Brey
|
||||||
|
* Copyright (C) 2022 Nextcloud GmbH
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.nextcloud.talk.dagger.modules
|
||||||
|
|
||||||
|
import androidx.lifecycle.ViewModel
|
||||||
|
import androidx.lifecycle.ViewModelProvider
|
||||||
|
import com.nextcloud.talk.viewmodels.SharedItemsViewModel
|
||||||
|
import dagger.Binds
|
||||||
|
import dagger.MapKey
|
||||||
|
import dagger.Module
|
||||||
|
import dagger.multibindings.IntoMap
|
||||||
|
import javax.inject.Inject
|
||||||
|
import javax.inject.Provider
|
||||||
|
import kotlin.reflect.KClass
|
||||||
|
|
||||||
|
class ViewModelFactory @Inject constructor(
|
||||||
|
private val viewModels: MutableMap<Class<out ViewModel>, Provider<ViewModel>>
|
||||||
|
) : ViewModelProvider.Factory {
|
||||||
|
override fun <T : ViewModel> create(modelClass: Class<T>): T = viewModels[modelClass]?.get() as T
|
||||||
|
}
|
||||||
|
|
||||||
|
@Target(AnnotationTarget.FUNCTION, AnnotationTarget.PROPERTY_GETTER, AnnotationTarget.PROPERTY_SETTER)
|
||||||
|
@Retention(AnnotationRetention.RUNTIME)
|
||||||
|
@MapKey
|
||||||
|
internal annotation class ViewModelKey(val value: KClass<out ViewModel>)
|
||||||
|
|
||||||
|
@Module
|
||||||
|
abstract class ViewModelModule {
|
||||||
|
|
||||||
|
@Binds
|
||||||
|
abstract fun bindViewModelFactory(factory: ViewModelFactory): ViewModelProvider.Factory
|
||||||
|
|
||||||
|
@Binds
|
||||||
|
@IntoMap
|
||||||
|
@ViewModelKey(SharedItemsViewModel::class)
|
||||||
|
abstract fun sharedItemsViewModel(viewModel: SharedItemsViewModel): ViewModel
|
||||||
|
}
|
@ -1,10 +1,8 @@
|
|||||||
package com.nextcloud.talk.repositories
|
package com.nextcloud.talk.repositories
|
||||||
|
|
||||||
import android.util.Log
|
import android.util.Log
|
||||||
import autodagger.AutoInjector
|
|
||||||
import com.nextcloud.talk.R
|
import com.nextcloud.talk.R
|
||||||
import com.nextcloud.talk.api.NcApi
|
import com.nextcloud.talk.api.NcApi
|
||||||
import com.nextcloud.talk.application.NextcloudTalkApplication
|
|
||||||
import com.nextcloud.talk.application.NextcloudTalkApplication.Companion.sharedApplication
|
import com.nextcloud.talk.application.NextcloudTalkApplication.Companion.sharedApplication
|
||||||
import com.nextcloud.talk.models.database.UserEntity
|
import com.nextcloud.talk.models.database.UserEntity
|
||||||
import com.nextcloud.talk.models.json.chat.ChatShareOverall
|
import com.nextcloud.talk.models.json.chat.ChatShareOverall
|
||||||
@ -14,15 +12,7 @@ import retrofit2.Response
|
|||||||
import java.util.Locale
|
import java.util.Locale
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
@AutoInjector(NextcloudTalkApplication::class)
|
class SharedItemsRepository @Inject constructor(private val ncApi: NcApi) {
|
||||||
class SharedItemsRepository {
|
|
||||||
|
|
||||||
@Inject
|
|
||||||
lateinit var ncApi: NcApi
|
|
||||||
|
|
||||||
init {
|
|
||||||
sharedApplication!!.componentApplication.inject(this)
|
|
||||||
}
|
|
||||||
|
|
||||||
fun media(parameters: Parameters, type: SharedItemType): Observable<SharedMediaItems>? {
|
fun media(parameters: Parameters, type: SharedItemType): Observable<SharedMediaItems>? {
|
||||||
return media(parameters, type, null)
|
return media(parameters, type, null)
|
||||||
|
@ -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.ViewModel
|
import androidx.lifecycle.ViewModel
|
||||||
import androidx.lifecycle.ViewModelProvider
|
|
||||||
import com.nextcloud.talk.models.database.UserEntity
|
import com.nextcloud.talk.models.database.UserEntity
|
||||||
import com.nextcloud.talk.repositories.SharedItemType
|
import com.nextcloud.talk.repositories.SharedItemType
|
||||||
import com.nextcloud.talk.repositories.SharedItemsRepository
|
import com.nextcloud.talk.repositories.SharedItemsRepository
|
||||||
@ -13,11 +12,10 @@ import io.reactivex.Observer
|
|||||||
import io.reactivex.android.schedulers.AndroidSchedulers
|
import io.reactivex.android.schedulers.AndroidSchedulers
|
||||||
import io.reactivex.disposables.Disposable
|
import io.reactivex.disposables.Disposable
|
||||||
import io.reactivex.schedulers.Schedulers
|
import io.reactivex.schedulers.Schedulers
|
||||||
|
import javax.inject.Inject
|
||||||
|
|
||||||
class SharedItemsViewModel(
|
class SharedItemsViewModel @Inject constructor(
|
||||||
private val repository: SharedItemsRepository,
|
private val repository: SharedItemsRepository
|
||||||
private val initialType: SharedItemType,
|
|
||||||
private val repositoryParameters: SharedItemsRepository.Parameters
|
|
||||||
) :
|
) :
|
||||||
ViewModel() {
|
ViewModel() {
|
||||||
|
|
||||||
@ -29,11 +27,12 @@ class SharedItemsViewModel(
|
|||||||
|
|
||||||
private val _sharedItems: MutableLiveData<SharedMediaItems> by lazy {
|
private val _sharedItems: MutableLiveData<SharedMediaItems> by lazy {
|
||||||
MutableLiveData<SharedMediaItems>().also {
|
MutableLiveData<SharedMediaItems>().also {
|
||||||
loadItems(initialType)
|
loadItems(_currentItemType)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private var _currentItemType = initialType
|
private lateinit var repositoryParameters: SharedItemsRepository.Parameters
|
||||||
|
private lateinit var _currentItemType: SharedItemType
|
||||||
|
|
||||||
val sharedItemTypes: LiveData<Set<SharedItemType>>
|
val sharedItemTypes: LiveData<Set<SharedItemType>>
|
||||||
get() = _sharedItemTypes
|
get() = _sharedItemTypes
|
||||||
@ -120,27 +119,16 @@ class SharedItemsViewModel(
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
class Factory(val userEntity: UserEntity, val roomToken: String, private val initialType: SharedItemType) :
|
// TODO cleanup
|
||||||
ViewModelProvider
|
fun initialize(userEntity: UserEntity, roomToken: String, initialType: SharedItemType) {
|
||||||
.Factory {
|
repositoryParameters = SharedItemsRepository.Parameters(
|
||||||
|
|
||||||
override fun <T : ViewModel?> create(modelClass: Class<T>): T {
|
|
||||||
if (modelClass.isAssignableFrom(SharedItemsViewModel::class.java)) {
|
|
||||||
|
|
||||||
val repository = SharedItemsRepository()
|
|
||||||
val repositoryParameters = SharedItemsRepository.Parameters(
|
|
||||||
userEntity.userId,
|
userEntity.userId,
|
||||||
userEntity.token,
|
userEntity.token,
|
||||||
userEntity.baseUrl,
|
userEntity.baseUrl,
|
||||||
userEntity,
|
userEntity,
|
||||||
roomToken
|
roomToken
|
||||||
)
|
)
|
||||||
|
_currentItemType = initialType
|
||||||
return SharedItemsViewModel(repository, initialType, repositoryParameters) as T
|
|
||||||
}
|
|
||||||
|
|
||||||
throw IllegalArgumentException("Unknown ViewModel class")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
Loading…
Reference in New Issue
Block a user