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") kotlin("kapt")
id("dagger.hilt.android.plugin") id("dagger.hilt.android.plugin")
id("kotlin-android") id("kotlin-android")
id("com.google.devtools.ksp") version "1.5.21-1.0.0-beta07"
} }
kapt { kapt {
@@ -77,11 +76,13 @@ android {
dependencies { dependencies {
implementation(project(":util")) implementation(project(":data"))
implementation(project(":i18n"))
implementation(Libs.activity_compose) implementation(Libs.activity_compose)
implementation(Libs.navigation_compose) implementation(Libs.navigation_compose)
implementation(Libs.core_ktx) implementation(Libs.core_ktx)
implementation(Libs.lifecycle_runtime_ktx)
implementation(Libs.preference_ktx) implementation(Libs.preference_ktx)
implementation(Libs.appcompat) implementation(Libs.appcompat)
implementation(Libs.startup_runtime) implementation(Libs.startup_runtime)
@@ -104,8 +105,6 @@ dependencies {
implementation(Libs.accompanist_placeholder) implementation(Libs.accompanist_placeholder)
implementation(Libs.accompanist_navigation_animation) implementation(Libs.accompanist_navigation_animation)
implementation(kotlin("reflect"))
implementation(platform(Libs.kotlin_coroutine_bom)) implementation(platform(Libs.kotlin_coroutine_bom))
testImplementation(Libs.kotlin_coroutine_test) testImplementation(Libs.kotlin_coroutine_test)
@@ -113,23 +112,16 @@ dependencies {
implementation(Libs.hilt_navigation_compose) implementation(Libs.hilt_navigation_compose)
kapt(Libs.hilt_android_compiler) kapt(Libs.hilt_android_compiler)
implementation(Libs.lifecycle_runtime_ktx)
testImplementation(Libs.junit_jupiter_api) testImplementation(Libs.junit_jupiter_api)
testImplementation(Libs.junit_jupiter_engine) 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.ksp_api)
implementation(Libs.orbit_mvi_core) implementation(Libs.orbit_mvi_core)
implementation(Libs.orbit_mvi_viewmodel) implementation(Libs.orbit_mvi_viewmodel)
testImplementation(Libs.orbit_mvi_test) testImplementation(Libs.orbit_mvi_test)
ksp(Libs.room_compiler) kapt(Libs.room_compiler)
implementation(Libs.room_runtime) implementation(Libs.room_runtime)
testImplementation(Libs.room_testing) testImplementation(Libs.room_testing)
@@ -137,6 +129,4 @@ dependencies {
androidTestImplementation(Libs.mockk_android) androidTestImplementation(Libs.mockk_android)
debugImplementation(Libs.leakcanary_android) debugImplementation(Libs.leakcanary_android)
implementation(Libs.timber)
} }
+24
View File
@@ -1,7 +1,21 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.ericampire.android.androidstudycase"> 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 <application
android:allowBackup="true" android:allowBackup="true"
android:icon="@mipmap/ic_launcher" android:icon="@mipmap/ic_launcher"
@@ -21,6 +35,16 @@
<category android:name="android.intent.category.LAUNCHER" /> <category android:name="android.intent.category.LAUNCHER" />
</intent-filter> </intent-filter>
</activity> </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> </application>
</manifest> </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.darkColors
import androidx.compose.material.lightColors import androidx.compose.material.lightColors
import androidx.compose.runtime.Composable import androidx.compose.runtime.Composable
import androidx.compose.ui.graphics.Color
private val DarkColorPalette = darkColors( private val DarkColorPalette = darkColors(
primary = Purple200, primary = Purple200,
@@ -15,16 +16,13 @@ private val DarkColorPalette = darkColors(
private val LightColorPalette = lightColors( private val LightColorPalette = lightColors(
primary = Purple500, primary = Purple500,
primaryVariant = Purple700, primaryVariant = Purple700,
secondary = Teal200 secondary = Teal200,
/* Other default colors to override
background = Color.White, background = Color.White,
surface = Color.White, surface = Color.White,
onPrimary = Color.White, onPrimary = Color.White,
onSecondary = Color.Black, onSecondary = Color.Black,
onBackground = Color.Black, onBackground = Color.Black,
onSurface = Color.Black, onSurface = Color.Black,
*/
) )
@Composable @Composable
-2
View File
@@ -11,8 +11,6 @@ buildscript {
classpath(Libs.kotlin_gradle_plugin) classpath(Libs.kotlin_gradle_plugin)
classpath(Libs.gradle_plugin) classpath(Libs.gradle_plugin)
classpath(Libs.hilt_gradle_plugin) classpath(Libs.hilt_gradle_plugin)
classpath(Libs.play_service_plugin)
classpath(Libs.firebase_crashlytics_plugin)
} }
} }
+1
View File
@@ -0,0 +1 @@
/build
+48
View File
@@ -0,0 +1,48 @@
plugins {
id("com.android.library")
id("kotlin-android")
kotlin("kapt")
}
android {
compileSdk = Apps.compileSdk
buildToolsVersion = Apps.buildToolsVersion
defaultConfig {
minSdk = Apps.minSdk
targetSdk = Apps.targetSdk
testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
consumerProguardFiles("consumer-rules.pro")
}
buildTypes {
release {
isMinifyEnabled = false
proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
}
}
compileOptions {
sourceCompatibility = JavaVersion.VERSION_1_8
targetCompatibility = JavaVersion.VERSION_1_8
}
}
dependencies {
api(project(":domain"))
implementation(Libs.core_ktx)
api(platform(Libs.kotlin_coroutine_bom))
api(Libs.kotlin_coroutine_core)
testImplementation(Libs.junit_jupiter_api)
testImplementation(Libs.junit_jupiter_engine)
testImplementation(Libs.mockk_core)
api(Libs.hilt_android)
kapt(Libs.hilt_android_compiler)
api(Libs.timber)
}
View File
+21
View File
@@ -0,0 +1,21 @@
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.kts.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html
# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}
# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable
# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile
+4
View File
@@ -0,0 +1,4 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest package="com.ericampire.android.androidstudycase.data">
</manifest>
@@ -0,0 +1,5 @@
package com.ericampire.android.androidstudycase.data.datasource.user
interface UserDataSource {
}
@@ -0,0 +1,6 @@
package com.ericampire.android.androidstudycase.data.di
object DataSourceModule {
}
@@ -0,0 +1,6 @@
package com.ericampire.android.androidstudycase.data.di
object RepositoryModule {
}
@@ -0,0 +1,11 @@
package com.ericampire.android.androidstudycase.data.repository
import com.ericampire.android.androidstudycase.data.datasource.user.UserDataSource
import com.ericampire.android.androidstudycase.domain.repository.UserRepository
import javax.inject.Inject
class UserRepositoryImpl @Inject constructor(
private val dataSource: UserDataSource
) : UserRepository {
}
@@ -1,4 +1,4 @@
package org.zxconnect.android.beserve.util package com.ericampire.android.androidstudycase.data
import org.junit.jupiter.api.Assertions.assertEquals import org.junit.jupiter.api.Assertions.assertEquals
import org.junit.jupiter.api.Test import org.junit.jupiter.api.Test
+1
View File
@@ -0,0 +1 @@
/build
+48
View File
@@ -0,0 +1,48 @@
plugins {
id("com.android.library")
id("kotlin-android")
kotlin("kapt")
}
android {
compileSdk = Apps.compileSdk
buildToolsVersion = Apps.buildToolsVersion
defaultConfig {
minSdk = Apps.minSdk
targetSdk = Apps.targetSdk
testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
consumerProguardFiles("consumer-rules.pro")
}
buildTypes {
release {
isMinifyEnabled = false
proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
}
}
compileOptions {
sourceCompatibility = JavaVersion.VERSION_1_8
targetCompatibility = JavaVersion.VERSION_1_8
}
}
dependencies {
api(project(":util"))
implementation(Libs.core_ktx)
api(platform(Libs.kotlin_coroutine_bom))
api(Libs.kotlin_coroutine_core)
testImplementation(Libs.junit_jupiter_api)
testImplementation(Libs.junit_jupiter_engine)
testImplementation(Libs.mockk_core)
api(Libs.hilt_android)
kapt(Libs.hilt_android_compiler)
api(Libs.timber)
}
View File
+21
View File
@@ -0,0 +1,21 @@
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.kts.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html
# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}
# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable
# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile
+4
View File
@@ -0,0 +1,4 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest package="com.ericampire.android.androidstudycase.domain">
</manifest>
@@ -0,0 +1,6 @@
package com.ericampire.android.androidstudycase.domain.di
object UseCaseModule {
}
@@ -0,0 +1,7 @@
package com.ericampire.android.androidstudycase.domain.entity
data class User(
val uid: String = "",
)
@@ -0,0 +1,2 @@
package com.ericampire.android.androidstudycase.domain.extension
@@ -0,0 +1,5 @@
package com.ericampire.android.androidstudycase.domain.mapper
interface Mapper<I, O> {
fun map(input: I): O
}
@@ -0,0 +1,6 @@
package com.ericampire.android.androidstudycase.domain.repository
interface UserRepository {
}
@@ -0,0 +1,2 @@
package com.ericampire.android.androidstudycase.domain.usecase
@@ -0,0 +1,18 @@
package com.ericampire.android.androidstudycase.domain
import org.junit.jupiter.api.Assertions.assertEquals
import org.junit.jupiter.api.Test
/**
* Example local unit test, which will execute on the development machine (host).
*
* See [testing documentation](http://d.android.com/tools/testing).
*/
class ExampleUnitTest {
@Test
fun addition_isCorrect() {
assertEquals(4, 2 + 2)
}
}
+7 -5
View File
@@ -8,13 +8,15 @@ refreshVersions {
dependencyResolutionManagement { dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories { repositories {
google() google()
mavenCentral() mavenCentral()
jcenter() // Warning: this repository is going to shut down soon jcenter() // Warning: this repository is going to shut down soon
} }
} }
rootProject.name = "android-study-case" rootProject.name = "android-study-case"
include(":app") include(":app")
include(":util") include(":util")
include(":i18n") include(":i18n")
include(":data")
include(":domain")
@@ -1,4 +1,5 @@
package org.zxconnect.android.beserve.util package com.ericampire.android.androidstudycase.util
import javax.inject.Qualifier import javax.inject.Qualifier
@@ -1,4 +1,4 @@
package org.zxconnect.android.beserve.util package com.ericampire.android.androidstudycase.util
import androidx.lifecycle.Observer import androidx.lifecycle.Observer
@@ -1,4 +1,4 @@
package org.zxconnect.android.beserve.util package com.ericampire.android.androidstudycase.util
import androidx.lifecycle.MutableLiveData import androidx.lifecycle.MutableLiveData
@@ -1,8 +1,9 @@
package org.zxconnect.android.beserve.util.usecase package com.ericampire.android.androidstudycase.util.usecase
import com.ericampire.android.androidstudycase.util.Result
import kotlinx.coroutines.CoroutineDispatcher import kotlinx.coroutines.CoroutineDispatcher
import kotlinx.coroutines.withContext import kotlinx.coroutines.withContext
import org.zxconnect.android.beserve.util.Result
import timber.log.Timber import timber.log.Timber
@@ -1,10 +1,10 @@
package org.zxconnect.android.beserve.util.usecase package com.ericampire.android.androidstudycase.util.usecase
import com.ericampire.android.androidstudycase.util.Result
import kotlinx.coroutines.CoroutineDispatcher import kotlinx.coroutines.CoroutineDispatcher
import kotlinx.coroutines.flow.Flow import kotlinx.coroutines.flow.Flow
import kotlinx.coroutines.flow.catch import kotlinx.coroutines.flow.catch
import kotlinx.coroutines.flow.flowOn import kotlinx.coroutines.flow.flowOn
import org.zxconnect.android.beserve.util.Result
/** /**
* Executes business logic in its execute method and keep posting updates to the result as * Executes business logic in its execute method and keep posting updates to the result as
@@ -0,0 +1,18 @@
package com.ericampire.android.androidstudycase.util
import org.junit.jupiter.api.Assertions.assertEquals
import org.junit.jupiter.api.Test
/**
* Example local unit test, which will execute on the development machine (host).
*
* See [testing documentation](http://d.android.com/tools/testing).
*/
class ExampleUnitTest {
@Test
fun addition_isCorrect() {
assertEquals(4, 2 + 2)
}
}
+1 -1
View File
@@ -7,7 +7,7 @@
#### suppress inspection "SpellCheckingInspection" for whole file #### suppress inspection "SpellCheckingInspection" for whole file
#### suppress inspection "UnusedProperty" for whole file #### suppress inspection "UnusedProperty" for whole file
plugin.android=7.0.1 plugin.android=7.0.2
version.androidx.activity=1.3.0-alpha08 version.androidx.activity=1.3.0-alpha08
version.androidx.preference=1.1.1 version.androidx.preference=1.1.1
version.androidx.appcompat=1.3.0 version.androidx.appcompat=1.3.0