Setup the template project

This commit is contained in:
2021-09-03 10:47:27 +02:00
parent 150bc30d7e
commit 8f70464fa3
38 changed files with 371 additions and 34 deletions
+4 -14
View File
@@ -7,7 +7,6 @@ plugins {
kotlin("kapt")
id("dagger.hilt.android.plugin")
id("kotlin-android")
id("com.google.devtools.ksp") version "1.5.21-1.0.0-beta07"
}
kapt {
@@ -77,11 +76,13 @@ android {
dependencies {
implementation(project(":util"))
implementation(project(":data"))
implementation(project(":i18n"))
implementation(Libs.activity_compose)
implementation(Libs.navigation_compose)
implementation(Libs.core_ktx)
implementation(Libs.lifecycle_runtime_ktx)
implementation(Libs.preference_ktx)
implementation(Libs.appcompat)
implementation(Libs.startup_runtime)
@@ -104,8 +105,6 @@ dependencies {
implementation(Libs.accompanist_placeholder)
implementation(Libs.accompanist_navigation_animation)
implementation(kotlin("reflect"))
implementation(platform(Libs.kotlin_coroutine_bom))
testImplementation(Libs.kotlin_coroutine_test)
@@ -113,23 +112,16 @@ dependencies {
implementation(Libs.hilt_navigation_compose)
kapt(Libs.hilt_android_compiler)
implementation(Libs.lifecycle_runtime_ktx)
testImplementation(Libs.junit_jupiter_api)
testImplementation(Libs.junit_jupiter_engine)
implementation(Libs.koin_android)
implementation(Libs.koin_androidx_compose)
implementation(Libs.koin_androidx_workmanager)
testImplementation(Libs.koin_test_junit5)
implementation(Libs.ksp_api)
implementation(Libs.orbit_mvi_core)
implementation(Libs.orbit_mvi_viewmodel)
testImplementation(Libs.orbit_mvi_test)
ksp(Libs.room_compiler)
kapt(Libs.room_compiler)
implementation(Libs.room_runtime)
testImplementation(Libs.room_testing)
@@ -137,6 +129,4 @@ dependencies {
androidTestImplementation(Libs.mockk_android)
debugImplementation(Libs.leakcanary_android)
implementation(Libs.timber)
}
+24
View File
@@ -1,7 +1,21 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.ericampire.android.androidstudycase">
<queries>
<intent>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="https" />
</intent>
<intent>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.APP_BROWSER" />
<data android:scheme="https" />
</intent>
</queries>
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
@@ -21,6 +35,16 @@
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<provider
android:name="androidx.startup.InitializationProvider"
android:authorities="${applicationId}.androidx-startup"
android:exported="false"
tools:node="merge">
<meta-data
android:name="com.ericampire.android.androidstudycase.app.initializer.TimberInitializer"
android:value="androidx.startup" />
</provider>
</application>
</manifest>
@@ -0,0 +1,24 @@
package com.ericampire.android.androidstudycase.app.di
import android.content.Context
import android.content.SharedPreferences
import androidx.preference.PreferenceManager
import dagger.Module
import dagger.Provides
import dagger.hilt.InstallIn
import dagger.hilt.android.qualifiers.ApplicationContext
import dagger.hilt.components.SingletonComponent
import javax.inject.Singleton
@Module
@InstallIn(SingletonComponent::class)
object AppModule {
@Provides
@Singleton
fun provideSharedPreference(
@ApplicationContext context: Context
): SharedPreferences {
return PreferenceManager.getDefaultSharedPreferences(context)
}
}
@@ -0,0 +1,30 @@
package com.ericampire.android.androidstudycase.app.di
import com.ericampire.android.androidstudycase.util.IoDispatcher
import com.ericampire.android.androidstudycase.util.MainDispatcher
import com.ericampire.android.androidstudycase.util.MainImmediateDispatcher
import dagger.Module
import dagger.Provides
import dagger.hilt.InstallIn
import dagger.hilt.components.SingletonComponent
import kotlinx.coroutines.CoroutineDispatcher
import kotlinx.coroutines.Dispatchers
@Module
@InstallIn(SingletonComponent::class)
object CoroutineModule {
@Provides
@IoDispatcher
fun providesIoDispatcher(): CoroutineDispatcher = Dispatchers.IO
@Provides
@MainDispatcher
fun providesMainDispatcher(): CoroutineDispatcher = Dispatchers.Main
@Provides
@MainImmediateDispatcher
fun providesMainImmediateDispatcher(): CoroutineDispatcher = Dispatchers.Main.immediate
}
@@ -0,0 +1,11 @@
package com.ericampire.android.androidstudycase.app.di
import dagger.Module
import dagger.hilt.InstallIn
import dagger.hilt.android.components.ViewModelComponent
@Module
@InstallIn(ViewModelComponent::class)
object ViewModelModule {
}
@@ -0,0 +1,18 @@
package com.ericampire.android.androidstudycase.app.initializer
import android.content.Context
import androidx.startup.Initializer
import com.ericampire.android.androidstudycase.BuildConfig
import timber.log.Timber
class TimberInitializer : Initializer<Unit> {
override fun create(context: Context) {
if (BuildConfig.DEBUG) {
Timber.plant(Timber.DebugTree())
}
}
override fun dependencies(): MutableList<Class<out Initializer<*>>> {
return mutableListOf()
}
}
@@ -5,6 +5,7 @@ import androidx.compose.material.MaterialTheme
import androidx.compose.material.darkColors
import androidx.compose.material.lightColors
import androidx.compose.runtime.Composable
import androidx.compose.ui.graphics.Color
private val DarkColorPalette = darkColors(
primary = Purple200,
@@ -15,16 +16,13 @@ private val DarkColorPalette = darkColors(
private val LightColorPalette = lightColors(
primary = Purple500,
primaryVariant = Purple700,
secondary = Teal200
/* Other default colors to override
secondary = Teal200,
background = Color.White,
surface = Color.White,
onPrimary = Color.White,
onSecondary = Color.Black,
onBackground = Color.Black,
onSurface = Color.Black,
*/
)
@Composable