├── app ├── .gitignore ├── src │ ├── main │ │ ├── res │ │ │ ├── values │ │ │ │ ├── strings.xml │ │ │ │ ├── colors.xml │ │ │ │ └── themes.xml │ │ │ ├── mipmap-hdpi │ │ │ │ ├── ic_launcher.png │ │ │ │ └── ic_launcher_round.png │ │ │ ├── mipmap-mdpi │ │ │ │ ├── ic_launcher.png │ │ │ │ └── ic_launcher_round.png │ │ │ ├── mipmap-xhdpi │ │ │ │ ├── ic_launcher.png │ │ │ │ └── ic_launcher_round.png │ │ │ ├── mipmap-xxhdpi │ │ │ │ ├── ic_launcher.png │ │ │ │ └── ic_launcher_round.png │ │ │ ├── mipmap-xxxhdpi │ │ │ │ ├── ic_launcher.png │ │ │ │ └── ic_launcher_round.png │ │ │ ├── mipmap-anydpi-v26 │ │ │ │ ├── ic_launcher.xml │ │ │ │ └── ic_launcher_round.xml │ │ │ ├── drawable │ │ │ │ ├── ic_baseline_share_24.xml │ │ │ │ └── ic_launcher_background.xml │ │ │ ├── values-night │ │ │ │ └── themes.xml │ │ │ └── drawable-v24 │ │ │ │ └── ic_launcher_foreground.xml │ │ ├── java │ │ │ └── com │ │ │ │ └── kriticalflare │ │ │ │ └── rickmorty │ │ │ │ ├── ui │ │ │ │ ├── Color.kt │ │ │ │ ├── Shape.kt │ │ │ │ ├── Type.kt │ │ │ │ └── Theme.kt │ │ │ │ ├── data │ │ │ │ ├── model │ │ │ │ │ ├── Origin.kt │ │ │ │ │ ├── Location.kt │ │ │ │ │ ├── CharactersResponse.kt │ │ │ │ │ ├── Info.kt │ │ │ │ │ ├── Episode.kt │ │ │ │ │ ├── Character.kt │ │ │ │ │ └── CharacterResponse.kt │ │ │ │ ├── network │ │ │ │ │ ├── RickMortyService.kt │ │ │ │ │ └── RickMortyClient.kt │ │ │ │ └── paging │ │ │ │ │ └── CharactersPaging.kt │ │ │ │ ├── routing │ │ │ │ └── Router.kt │ │ │ │ ├── characters │ │ │ │ ├── CharactersViewModel.kt │ │ │ │ ├── CharacterDetailScreen.kt │ │ │ │ └── CharacterScreen.kt │ │ │ │ ├── components │ │ │ │ ├── RickMortyAppBar.kt │ │ │ │ └── CharacterItem.kt │ │ │ │ └── MainActivity.kt │ │ └── AndroidManifest.xml │ ├── test │ │ └── java │ │ │ └── com │ │ │ └── kriticalflare │ │ │ └── rickmorty │ │ │ └── ExampleUnitTest.kt │ └── androidTest │ │ └── java │ │ └── com │ │ └── kriticalflare │ │ └── rickmorty │ │ └── ExampleInstrumentedTest.kt ├── proguard-rules.pro └── build.gradle ├── settings.gradle ├── .idea ├── .gitignore ├── codeStyles │ ├── codeStyleConfig.xml │ └── Project.xml ├── compiler.xml ├── vcs.xml ├── misc.xml ├── gradle.xml └── jarRepositories.xml ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── .gitignore ├── README.md ├── gradle.properties ├── gradlew.bat └── gradlew /app/.gitignore: -------------------------------------------------------------------------------- 1 | /build -------------------------------------------------------------------------------- /settings.gradle: -------------------------------------------------------------------------------- 1 | rootProject.name = "rickmorty" 2 | include ':app' 3 | -------------------------------------------------------------------------------- /.idea/.gitignore: -------------------------------------------------------------------------------- 1 | # Default ignored files 2 | /shelf/ 3 | /workspace.xml 4 | -------------------------------------------------------------------------------- /app/src/main/res/values/strings.xml: -------------------------------------------------------------------------------- 1 | 2 | rickmorty 3 | -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /app/src/main/res/mipmap-hdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-hdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-mdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-mdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-xhdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-xxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-hdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-hdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-mdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-mdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xhdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kriticalflare/Rick-Morty-Compose/master/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /.idea/codeStyles/codeStyleConfig.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 5 | -------------------------------------------------------------------------------- /.idea/compiler.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /.idea/vcs.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | #Wed Sep 09 21:33:25 IST 2020 2 | distributionBase=GRADLE_USER_HOME 3 | distributionUrl=https://services.gradle.org/distributions/gradle-6.7-bin.zip 4 | distributionPath=wrapper/dists 5 | zipStorePath=wrapper/dists 6 | zipStoreBase=GRADLE_USER_HOME 7 | -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/ui/Color.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.ui 2 | 3 | import androidx.compose.ui.graphics.Color 4 | 5 | val purple200 = Color(0xFFBB86FC) 6 | val purple500 = Color(0xFF6200EE) 7 | val purple700 = Color(0xFF3700B3) 8 | val teal200 = Color(0xFF03DAC5) -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | *.iml 2 | .gradle 3 | /local.properties 4 | /.idea/caches 5 | /.idea/libraries 6 | /.idea/modules.xml 7 | /.idea/workspace.xml 8 | /.idea/navEditor.xml 9 | /.idea/assetWizardSettings.xml 10 | .DS_Store 11 | /build 12 | /captures 13 | .externalNativeBuild 14 | .cxx 15 | local.properties 16 | -------------------------------------------------------------------------------- /app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | -------------------------------------------------------------------------------- /app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/model/Origin.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.model 2 | 3 | 4 | import com.squareup.moshi.Json 5 | import com.squareup.moshi.JsonClass 6 | 7 | @JsonClass(generateAdapter = true) 8 | data class Origin( 9 | @Json(name = "name") 10 | val name: String, 11 | @Json(name = "url") 12 | val url: String 13 | ) -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/model/Location.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.model 2 | 3 | 4 | import com.squareup.moshi.Json 5 | import com.squareup.moshi.JsonClass 6 | 7 | @JsonClass(generateAdapter = true) 8 | data class Location( 9 | @Json(name = "name") 10 | val name: String, 11 | @Json(name = "url") 12 | val url: String 13 | ) -------------------------------------------------------------------------------- /.idea/misc.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 9 | -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/model/CharactersResponse.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.model 2 | 3 | 4 | import com.squareup.moshi.Json 5 | import com.squareup.moshi.JsonClass 6 | 7 | @JsonClass(generateAdapter = true) 8 | data class CharactersResponse( 9 | @Json(name = "info") 10 | val info: Info, 11 | @Json(name = "results") 12 | val results: List 13 | ) -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/ui/Shape.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.ui 2 | 3 | import androidx.compose.foundation.shape.RoundedCornerShape 4 | import androidx.compose.material.Shapes 5 | import androidx.compose.ui.unit.dp 6 | 7 | val shapes = Shapes( 8 | small = RoundedCornerShape(4.dp), 9 | medium = RoundedCornerShape(4.dp), 10 | large = RoundedCornerShape(0.dp) 11 | ) -------------------------------------------------------------------------------- /app/src/main/res/values/colors.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | #FFBB86FC 4 | #FF6200EE 5 | #FF3700B3 6 | #FF03DAC5 7 | #FF018786 8 | #FF000000 9 | #FFFFFFFF 10 | -------------------------------------------------------------------------------- /app/src/test/java/com/kriticalflare/rickmorty/ExampleUnitTest.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty 2 | 3 | import org.junit.Test 4 | 5 | import org.junit.Assert.* 6 | 7 | /** 8 | * Example local unit test, which will execute on the development machine (host). 9 | * 10 | * See [testing documentation](http://d.android.com/tools/testing). 11 | */ 12 | class ExampleUnitTest { 13 | @Test 14 | fun addition_isCorrect() { 15 | assertEquals(4, 2 + 2) 16 | } 17 | } -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/model/Info.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.model 2 | 3 | 4 | import com.squareup.moshi.Json 5 | import com.squareup.moshi.JsonClass 6 | 7 | @JsonClass(generateAdapter = true) 8 | data class Info( 9 | @Json(name = "count") 10 | val count: Int, 11 | @Json(name = "next") 12 | val next: String?, 13 | @Json(name = "pages") 14 | val pages: Int, 15 | @Json(name = "prev") 16 | val prev: String? 17 | ) -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Rick-Morty-Compose 2 | Android app using Jetpack Compose and Rick and Morty API built using 3 | * Compose 4 | * Retrofit 5 | * ViewModel 6 | * Coroutines 7 | * Moshi 8 | * [Accompanist](https://github.com/chrisbanes/accompanist) 9 | * [Rick And Morty API](https://rickandmortyapi.com) 10 | * [Navigation Component Compose](https://developer.android.com/jetpack/compose/navigation) 11 | * [Paging Compose](https://developer.android.com/jetpack/androidx/releases/paging#paging_compose_version_100_2) 12 | -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/network/RickMortyService.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.network 2 | 3 | import com.kriticalflare.rickmorty.data.model.CharacterResponse 4 | import com.kriticalflare.rickmorty.data.model.CharactersResponse 5 | import retrofit2.http.GET 6 | import retrofit2.http.Path 7 | import retrofit2.http.Query 8 | 9 | interface RickMortyService { 10 | 11 | @GET("character/") 12 | suspend fun getAllCharacters(@Query("page") page: Int): CharactersResponse 13 | 14 | @GET("character/{id}") 15 | suspend fun getCharacter(@Path("id") id: Int): CharacterResponse 16 | } -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/routing/Router.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.routing 2 | 3 | 4 | sealed class Screen( 5 | val route: String, 6 | val routeWithoutArgs: String, 7 | val args: String, 8 | val title: String 9 | ) { 10 | object CharacterScreen : Screen( 11 | "CharacterScreen", 12 | "CharacterScreen", 13 | "", 14 | "Rick And Morty" 15 | ) 16 | object CharacterDetailScreen : 17 | Screen( 18 | "CharacterDetailScreen/{id}", 19 | "CharacterDetailScreen/", 20 | "{id}", 21 | "Character" 22 | ) 23 | } -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/model/Episode.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.model 2 | 3 | 4 | import com.squareup.moshi.Json 5 | import com.squareup.moshi.JsonClass 6 | 7 | @JsonClass(generateAdapter = true) 8 | data class Episode( 9 | @Json(name = "air_date") 10 | val airDate: String, 11 | @Json(name = "characters") 12 | val characters: List, 13 | @Json(name = "created") 14 | val created: String, 15 | @Json(name = "episode") 16 | val episode: String, 17 | @Json(name = "id") 18 | val id: Int, 19 | @Json(name = "name") 20 | val name: String, 21 | @Json(name = "url") 22 | val url: String 23 | ) -------------------------------------------------------------------------------- /app/src/main/res/drawable/ic_baseline_share_24.xml: -------------------------------------------------------------------------------- 1 | 7 | 10 | 11 | -------------------------------------------------------------------------------- /.idea/gradle.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 19 | 20 | -------------------------------------------------------------------------------- /app/proguard-rules.pro: -------------------------------------------------------------------------------- 1 | # Add project specific ProGuard rules here. 2 | # You can control the set of applied configuration files using the 3 | # proguardFiles setting in build.gradle. 4 | # 5 | # For more details, see 6 | # http://developer.android.com/guide/developing/tools/proguard.html 7 | 8 | # If your project uses WebView with JS, uncomment the following 9 | # and specify the fully qualified class name to the JavaScript interface 10 | # class: 11 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { 12 | # public *; 13 | #} 14 | 15 | # Uncomment this to preserve the line number information for 16 | # debugging stack traces. 17 | #-keepattributes SourceFile,LineNumberTable 18 | 19 | # If you keep the line number information, uncomment this to 20 | # hide the original source file name. 21 | #-renamesourcefileattribute SourceFile -------------------------------------------------------------------------------- /app/src/androidTest/java/com/kriticalflare/rickmorty/ExampleInstrumentedTest.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty 2 | 3 | import androidx.test.platform.app.InstrumentationRegistry 4 | import androidx.test.ext.junit.runners.AndroidJUnit4 5 | 6 | import org.junit.Test 7 | import org.junit.runner.RunWith 8 | 9 | import org.junit.Assert.* 10 | 11 | /** 12 | * Instrumented test, which will execute on an Android device. 13 | * 14 | * See [testing documentation](http://d.android.com/tools/testing). 15 | */ 16 | @RunWith(AndroidJUnit4::class) 17 | class ExampleInstrumentedTest { 18 | @Test 19 | fun useAppContext() { 20 | // Context of the app under test. 21 | val appContext = InstrumentationRegistry.getInstrumentation().targetContext 22 | assertEquals("com.kriticalflare.rickmorty", appContext.packageName) 23 | } 24 | } -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/network/RickMortyClient.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.network 2 | 3 | import okhttp3.OkHttpClient 4 | import retrofit2.Retrofit 5 | import retrofit2.converter.moshi.MoshiConverterFactory 6 | import java.util.concurrent.TimeUnit 7 | 8 | object RickMortyClient { 9 | val INSTANCE: RickMortyService by lazy{ 10 | Retrofit.Builder() 11 | .client( 12 | OkHttpClient.Builder() 13 | .connectTimeout(30, TimeUnit.SECONDS) 14 | .readTimeout(30, TimeUnit.SECONDS) 15 | .writeTimeout(30, TimeUnit.SECONDS) 16 | .build() 17 | ) 18 | .baseUrl("https://rickandmortyapi.com/api/") 19 | .addConverterFactory(MoshiConverterFactory.create()) 20 | .build() 21 | .create(RickMortyService::class.java) 22 | } 23 | } -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/model/Character.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.model 2 | 3 | 4 | import com.squareup.moshi.Json 5 | import com.squareup.moshi.JsonClass 6 | 7 | @JsonClass(generateAdapter = true) 8 | data class Character( 9 | @Json(name = "created") 10 | val created: String, 11 | @Json(name = "episode") 12 | val episode: List, 13 | @Json(name = "gender") 14 | val gender: String, 15 | @Json(name = "id") 16 | val id: Int, 17 | @Json(name = "image") 18 | val image: String, 19 | @Json(name = "location") 20 | val location: Location, 21 | @Json(name = "name") 22 | val name: String, 23 | @Json(name = "origin") 24 | val origin: Origin, 25 | @Json(name = "species") 26 | val species: String, 27 | @Json(name = "status") 28 | val status: String, 29 | @Json(name = "type") 30 | val type: String, 31 | @Json(name = "url") 32 | val url: String 33 | ) -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/characters/CharactersViewModel.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.characters 2 | 3 | import androidx.lifecycle.ViewModel 4 | import androidx.compose.runtime.getValue 5 | import androidx.compose.runtime.mutableStateOf 6 | import androidx.compose.runtime.setValue 7 | import androidx.lifecycle.viewModelScope 8 | import com.kriticalflare.rickmorty.data.model.CharacterResponse 9 | import com.kriticalflare.rickmorty.data.network.RickMortyClient 10 | import kotlinx.coroutines.launch 11 | 12 | class CharactersViewModel(): ViewModel(){ 13 | 14 | var charLoading: Boolean by mutableStateOf(true) 15 | lateinit var character: CharacterResponse 16 | 17 | 18 | fun getCharacter(id: Int){ 19 | viewModelScope.launch { 20 | charLoading = true 21 | val response = RickMortyClient.INSTANCE.getCharacter(id) 22 | character = response 23 | charLoading = false 24 | } 25 | } 26 | } -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/model/CharacterResponse.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.model 2 | 3 | 4 | import com.squareup.moshi.Json 5 | import com.squareup.moshi.JsonClass 6 | 7 | @JsonClass(generateAdapter = true) 8 | data class CharacterResponse( 9 | @Json(name = "created") 10 | val created: String, 11 | @Json(name = "episode") 12 | val episode: List, 13 | @Json(name = "gender") 14 | val gender: String, 15 | @Json(name = "id") 16 | val id: Int, 17 | @Json(name = "image") 18 | val image: String, 19 | @Json(name = "location") 20 | val location: Location, 21 | @Json(name = "name") 22 | val name: String, 23 | @Json(name = "origin") 24 | val origin: Origin, 25 | @Json(name = "species") 26 | val species: String, 27 | @Json(name = "status") 28 | val status: String, 29 | @Json(name = "type") 30 | val type: String, 31 | @Json(name = "url") 32 | val url: String 33 | ) -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/ui/Type.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.ui 2 | 3 | import androidx.compose.material.Typography 4 | import androidx.compose.ui.text.TextStyle 5 | import androidx.compose.ui.text.font.FontFamily 6 | import androidx.compose.ui.text.font.FontWeight 7 | import androidx.compose.ui.unit.sp 8 | 9 | // Set of Material typography styles to start with 10 | val typography = Typography( 11 | body1 = TextStyle( 12 | fontFamily = FontFamily.Default, 13 | fontWeight = FontWeight.Normal, 14 | fontSize = 16.sp 15 | ) 16 | /* Other default text styles to override 17 | button = TextStyle( 18 | fontFamily = FontFamily.Default, 19 | fontWeight = FontWeight.W500, 20 | fontSize = 14.sp 21 | ), 22 | caption = TextStyle( 23 | fontFamily = FontFamily.Default, 24 | fontWeight = FontWeight.Normal, 25 | fontSize = 12.sp 26 | ) 27 | */ 28 | ) -------------------------------------------------------------------------------- /app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 12 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | -------------------------------------------------------------------------------- /app/src/main/res/values-night/themes.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 18 | -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/data/paging/CharactersPaging.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.data.paging 2 | 3 | import androidx.paging.PagingSource 4 | import com.kriticalflare.rickmorty.data.model.Character 5 | import com.kriticalflare.rickmorty.data.network.RickMortyClient 6 | 7 | class CharactersPaging { 8 | 9 | fun getCharacters(): PagingSource { 10 | return object : PagingSource() { 11 | override suspend fun load(params: LoadParams): LoadResult { 12 | val pageNumber = params.key ?: 0 13 | 14 | val charactersResponse = RickMortyClient.INSTANCE.getAllCharacters(page = pageNumber) 15 | val characters = charactersResponse.results 16 | 17 | val prevKey = if (pageNumber > 0) pageNumber - 1 else null 18 | val nextKey = if (charactersResponse.info.next != null) pageNumber + 1 else null 19 | 20 | return LoadResult.Page( 21 | data = characters, 22 | prevKey = prevKey, 23 | nextKey = nextKey 24 | ) 25 | } 26 | } 27 | } 28 | 29 | } 30 | -------------------------------------------------------------------------------- /gradle.properties: -------------------------------------------------------------------------------- 1 | # Project-wide Gradle settings. 2 | # IDE (e.g. Android Studio) users: 3 | # Gradle settings configured through the IDE *will override* 4 | # any settings specified in this file. 5 | # For more details on how to configure your build environment visit 6 | # http://www.gradle.org/docs/current/userguide/build_environment.html 7 | # Specifies the JVM arguments used for the daemon process. 8 | # The setting is particularly useful for tweaking memory settings. 9 | org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8 10 | # When configured, Gradle will run in incubating parallel mode. 11 | # This option should only be used with decoupled projects. More details, visit 12 | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects 13 | # org.gradle.parallel=true 14 | # AndroidX package structure to make it clearer which packages are bundled with the 15 | # Android operating system, and which are packaged with your app"s APK 16 | # https://developer.android.com/topic/libraries/support-library/androidx-rn 17 | android.useAndroidX=true 18 | # Automatically convert third-party libraries to use AndroidX 19 | android.enableJetifier=true 20 | # Kotlin code style for this project: "official" or "obsolete": 21 | kotlin.code.style=official -------------------------------------------------------------------------------- /app/src/main/java/com/kriticalflare/rickmorty/ui/Theme.kt: -------------------------------------------------------------------------------- 1 | package com.kriticalflare.rickmorty.ui 2 | 3 | import androidx.compose.foundation.isSystemInDarkTheme 4 | import androidx.compose.material.MaterialTheme 5 | import androidx.compose.material.darkColors 6 | import androidx.compose.material.lightColors 7 | import androidx.compose.runtime.Composable 8 | 9 | private val DarkColorPalette = darkColors( 10 | primary = purple200, 11 | primaryVariant = purple700, 12 | secondary = teal200 13 | ) 14 | 15 | private val LightColorPalette = lightColors( 16 | primary = purple500, 17 | primaryVariant = purple700, 18 | secondary = teal200 19 | 20 | /* Other default colors to override 21 | background = Color.White, 22 | surface = Color.White, 23 | onPrimary = Color.White, 24 | onSecondary = Color.Black, 25 | onBackground = Color.Black, 26 | onSurface = Color.Black, 27 | */ 28 | ) 29 | 30 | @Composable 31 | fun RickmortyTheme(darkTheme: Boolean = isSystemInDarkTheme(), content: @Composable() () -> Unit) { 32 | val colors = if (darkTheme) { 33 | DarkColorPalette 34 | } else { 35 | LightColorPalette 36 | } 37 | 38 | MaterialTheme( 39 | colors = colors, 40 | typography = typography, 41 | shapes = shapes, 42 | content = content 43 | ) 44 | } -------------------------------------------------------------------------------- /app/src/main/res/values/themes.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 18 | 19 | 23 | 24 |