MrOzOn 5 years ago
parent
commit
81d87a9693

+ 31 - 0
feature_measure/src/main/java/com/mrozon/feature_measure/di/DaggerViewModelFactory.kt

@@ -0,0 +1,31 @@
+package com.mrozon.feature_measure.di
+
+import androidx.lifecycle.ViewModel
+import androidx.lifecycle.ViewModelProvider
+import javax.inject.Inject
+import javax.inject.Provider
+
+class DaggerViewModelFactory @Inject constructor(
+    private val creators: @JvmSuppressWildcards Map<Class<out ViewModel>, Provider<ViewModel>>
+) : ViewModelProvider.Factory {
+    override fun <T : ViewModel> create(modelClass: Class<T>): T {
+        var creator: Provider<out ViewModel>? = creators[modelClass]
+        if (creator == null) {
+            for ((key, value) in creators) {
+                if (modelClass.isAssignableFrom(key)) {
+                    creator = value
+                    break
+                }
+            }
+        }
+        if (creator == null) {
+            throw IllegalArgumentException("Unknown model class: $modelClass")
+        }
+        try {
+            @Suppress("UNCHECKED_CAST")
+            return creator.get() as T
+        } catch (e: Exception) {
+            throw RuntimeException(e)
+        }
+    }
+}

+ 32 - 0
feature_measure/src/main/java/com/mrozon/feature_measure/di/TabMeasureFragmentComponent.kt

@@ -0,0 +1,32 @@
+package com.mrozon.feature_measure.di
+
+import com.mrozon.core_api.providers.AppWithFacade
+import com.mrozon.core_api.providers.ProvidersFacade
+import com.mrozon.feature_measure.presentation.TabMeasureFragment
+import dagger.Component
+import javax.inject.Singleton
+
+@Singleton
+@Component(
+    modules = [TabMeasureFragmentModule::class],
+    dependencies = [ProvidersFacade::class]
+)
+interface TabMeasureFragmentComponent {
+
+    companion object {
+        fun create(providersFacade: ProvidersFacade): TabMeasureFragmentComponent {
+            return DaggerTabMeasureFragmentComponent.builder()
+                .providersFacade(providersFacade)
+                .build()
+        }
+        fun injectFragment(fragment: TabMeasureFragment): TabMeasureFragmentComponent  {
+            val component = create((fragment.activity?.application
+                    as AppWithFacade).getFacade())
+            component.inject(fragment)
+            return component
+        }
+    }
+
+    fun inject(fragment: TabMeasureFragment)
+
+}

+ 20 - 0
feature_measure/src/main/java/com/mrozon/feature_measure/di/TabMeasureFragmentModule.kt

@@ -0,0 +1,20 @@
+package com.mrozon.feature_measure.di
+
+import androidx.lifecycle.ViewModel
+import androidx.lifecycle.ViewModelProvider
+import com.mrozon.core_api.viewmodel.ViewModelKey
+import com.mrozon.feature_measure.presentation.TabMeasureFragmentViewModel
+import dagger.Binds
+import dagger.Module
+import dagger.multibindings.IntoMap
+
+@Module
+interface TabMeasureFragmentModule {
+    @Binds
+    @IntoMap
+    @ViewModelKey(TabMeasureFragmentViewModel::class)
+    fun bindViewModel(viewmodel: TabMeasureFragmentViewModel): ViewModel
+
+    @Binds
+    fun viewModelFactory(factory: DaggerViewModelFactory): ViewModelProvider.Factory
+}

+ 14 - 0
feature_measure/src/main/java/com/mrozon/feature_measure/presentation/TabMeasureFragment.kt

@@ -0,0 +1,14 @@
+package com.mrozon.feature_measure.presentation
+
+import com.mrozon.feature_measure.R
+import com.mrozon.feature_measure.databinding.FragmentTabMeasureBinding
+import com.mrozon.utils.base.BaseFragment
+
+class TabMeasureFragment: BaseFragment<FragmentTabMeasureBinding>() {
+
+    override fun getLayoutId(): Int = R.layout.fragment_tab_measure
+
+    override fun subscribeUi() {
+
+    }
+}

+ 9 - 0
feature_measure/src/main/java/com/mrozon/feature_measure/presentation/TabMeasureFragmentViewModel.kt

@@ -0,0 +1,9 @@
+package com.mrozon.feature_measure.presentation
+
+import com.mrozon.utils.base.BaseViewModel
+import javax.inject.Inject
+
+class TabMeasureFragmentViewModel @Inject constructor(
+
+): BaseViewModel() {
+}

+ 13 - 0
feature_measure/src/main/res/layout/fragment_tab_measure.xml

@@ -0,0 +1,13 @@
+<?xml version="1.0" encoding="utf-8"?>
+<layout xmlns:android="http://schemas.android.com/apk/res/android">
+
+    <data>
+
+    </data>
+
+    <androidx.constraintlayout.widget.ConstraintLayout
+        android:layout_width="match_parent"
+        android:layout_height="match_parent">
+
+    </androidx.constraintlayout.widget.ConstraintLayout>
+</layout>