├── .gitignore ├── .idea ├── .gitignore ├── compiler.xml ├── deploymentTargetDropDown.xml ├── gradle.xml ├── misc.xml └── sonarlint │ └── issuestore │ └── index.pb ├── app ├── .gitignore ├── build.gradle ├── proguard-rules.pro └── src │ ├── androidTest │ └── java │ │ └── com │ │ └── plcoding │ │ └── ktorclientandroid │ │ └── ExampleInstrumentedTest.kt │ ├── main │ ├── AndroidManifest.xml │ ├── java │ │ └── com │ │ │ └── plcoding │ │ │ └── ktorclientandroid │ │ │ ├── MainActivity.kt │ │ │ ├── data │ │ │ └── remote │ │ │ │ ├── HttpRoutes.kt │ │ │ │ ├── PostsService.kt │ │ │ │ ├── PostsServiceImpl.kt │ │ │ │ └── dto │ │ │ │ ├── PostRequest.kt │ │ │ │ └── PostResponse.kt │ │ │ └── ui │ │ │ └── theme │ │ │ ├── Color.kt │ │ │ ├── Shape.kt │ │ │ ├── Theme.kt │ │ │ └── Type.kt │ └── res │ │ ├── drawable-v24 │ │ └── ic_launcher_foreground.xml │ │ ├── drawable │ │ └── ic_launcher_background.xml │ │ ├── mipmap-anydpi-v26 │ │ ├── ic_launcher.xml │ │ └── ic_launcher_round.xml │ │ ├── mipmap-hdpi │ │ ├── ic_launcher.webp │ │ └── ic_launcher_round.webp │ │ ├── mipmap-mdpi │ │ ├── ic_launcher.webp │ │ └── ic_launcher_round.webp │ │ ├── mipmap-xhdpi │ │ ├── ic_launcher.webp │ │ └── ic_launcher_round.webp │ │ ├── mipmap-xxhdpi │ │ ├── ic_launcher.webp │ │ └── ic_launcher_round.webp │ │ ├── mipmap-xxxhdpi │ │ ├── ic_launcher.webp │ │ └── ic_launcher_round.webp │ │ ├── values-night │ │ └── themes.xml │ │ └── values │ │ ├── colors.xml │ │ ├── strings.xml │ │ └── themes.xml │ └── test │ └── java │ └── com │ └── plcoding │ └── ktorclientandroid │ └── ExampleUnitTest.kt ├── build.gradle ├── gradle.properties ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat └── settings.gradle /.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 | -------------------------------------------------------------------------------- /.idea/.gitignore: -------------------------------------------------------------------------------- 1 | # Default ignored files 2 | /shelf/ 3 | /workspace.xml 4 | -------------------------------------------------------------------------------- /.idea/compiler.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /.idea/deploymentTargetDropDown.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | -------------------------------------------------------------------------------- /.idea/gradle.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 18 | 19 | -------------------------------------------------------------------------------- /.idea/misc.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 9 | -------------------------------------------------------------------------------- /.idea/sonarlint/issuestore/index.pb: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/.idea/sonarlint/issuestore/index.pb -------------------------------------------------------------------------------- /app/.gitignore: -------------------------------------------------------------------------------- 1 | /build -------------------------------------------------------------------------------- /app/build.gradle: -------------------------------------------------------------------------------- 1 | plugins { 2 | id 'com.android.application' 3 | id 'kotlin-android' 4 | id 'org.jetbrains.kotlin.plugin.serialization' 5 | } 6 | 7 | android { 8 | compileSdk 31 9 | 10 | defaultConfig { 11 | applicationId "com.plcoding.ktorclientandroid" 12 | minSdk 21 13 | targetSdk 31 14 | versionCode 1 15 | versionName "1.0" 16 | 17 | testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" 18 | vectorDrawables { 19 | useSupportLibrary true 20 | } 21 | } 22 | 23 | buildTypes { 24 | release { 25 | minifyEnabled false 26 | proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' 27 | } 28 | } 29 | compileOptions { 30 | sourceCompatibility JavaVersion.VERSION_1_8 31 | targetCompatibility JavaVersion.VERSION_1_8 32 | } 33 | kotlinOptions { 34 | jvmTarget = '1.8' 35 | useIR = true 36 | } 37 | buildFeatures { 38 | compose true 39 | } 40 | composeOptions { 41 | kotlinCompilerExtensionVersion compose_version 42 | kotlinCompilerVersion '1.5.21' 43 | } 44 | packagingOptions { 45 | resources { 46 | excludes += '/META-INF/{AL2.0,LGPL2.1}' 47 | } 48 | } 49 | } 50 | 51 | dependencies { 52 | 53 | implementation 'androidx.core:core-ktx:1.6.0' 54 | implementation 'androidx.appcompat:appcompat:1.3.1' 55 | implementation 'com.google.android.material:material:1.4.0' 56 | implementation "androidx.compose.ui:ui:$compose_version" 57 | implementation "androidx.compose.material:material:$compose_version" 58 | implementation "androidx.compose.ui:ui-tooling-preview:$compose_version" 59 | implementation 'androidx.lifecycle:lifecycle-runtime-ktx:2.3.1' 60 | implementation 'androidx.activity:activity-compose:1.3.1' 61 | testImplementation 'junit:junit:4.+' 62 | androidTestImplementation 'androidx.test.ext:junit:1.1.3' 63 | androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0' 64 | androidTestImplementation "androidx.compose.ui:ui-test-junit4:$compose_version" 65 | debugImplementation "androidx.compose.ui:ui-tooling:$compose_version" 66 | 67 | def ktor_version = "1.6.3" 68 | implementation "io.ktor:ktor-client-core:$ktor_version" 69 | implementation "io.ktor:ktor-client-android:$ktor_version" 70 | implementation "io.ktor:ktor-client-serialization:$ktor_version" 71 | implementation "io.ktor:ktor-client-logging:$ktor_version" 72 | implementation "ch.qos.logback:logback-classic:1.2.3" 73 | 74 | implementation "org.jetbrains.kotlinx:kotlinx-serialization-json:1.3.0" 75 | } -------------------------------------------------------------------------------- /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/plcoding/ktorclientandroid/ExampleInstrumentedTest.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid 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.plcoding.ktorclientandroid", appContext.packageName) 23 | } 24 | } -------------------------------------------------------------------------------- /app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 6 | 7 | 14 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/MainActivity.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid 2 | 3 | import android.os.Bundle 4 | import androidx.activity.ComponentActivity 5 | import androidx.activity.compose.setContent 6 | import androidx.compose.foundation.layout.* 7 | import androidx.compose.foundation.lazy.LazyColumn 8 | import androidx.compose.foundation.lazy.items 9 | import androidx.compose.material.MaterialTheme 10 | import androidx.compose.material.Surface 11 | import androidx.compose.material.Text 12 | import androidx.compose.runtime.Composable 13 | import androidx.compose.runtime.produceState 14 | import androidx.compose.ui.Modifier 15 | import androidx.compose.ui.tooling.preview.Preview 16 | import androidx.compose.ui.unit.dp 17 | import androidx.compose.ui.unit.sp 18 | import com.plcoding.ktorclientandroid.data.remote.PostsService 19 | import com.plcoding.ktorclientandroid.data.remote.dto.PostResponse 20 | import com.plcoding.ktorclientandroid.ui.theme.KtorClientAndroidTheme 21 | 22 | class MainActivity : ComponentActivity() { 23 | 24 | private val service = PostsService.create() 25 | 26 | override fun onCreate(savedInstanceState: Bundle?) { 27 | super.onCreate(savedInstanceState) 28 | setContent { 29 | val posts = produceState>( 30 | initialValue = emptyList(), 31 | producer = { 32 | value = service.getPosts() 33 | } 34 | ) 35 | KtorClientAndroidTheme { 36 | Surface(color = MaterialTheme.colors.background) { 37 | LazyColumn { 38 | items(posts.value) { 39 | Column( 40 | modifier = Modifier 41 | .fillMaxWidth() 42 | .padding(16.dp) 43 | ) { 44 | Text(text = it.title, fontSize = 20.sp) 45 | Spacer(modifier = Modifier.height(4.dp)) 46 | Text(text = it.body, fontSize = 14.sp) 47 | } 48 | } 49 | } 50 | } 51 | } 52 | } 53 | } 54 | } -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/data/remote/HttpRoutes.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.data.remote 2 | 3 | object HttpRoutes { 4 | 5 | private const val BASE_URL = "https://jsonplaceholder.typicode.com" 6 | const val POSTS = "$BASE_URL/posts" 7 | } -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/data/remote/PostsService.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.data.remote 2 | 3 | import com.plcoding.ktorclientandroid.data.remote.dto.PostRequest 4 | import com.plcoding.ktorclientandroid.data.remote.dto.PostResponse 5 | import io.ktor.client.* 6 | import io.ktor.client.engine.android.* 7 | import io.ktor.client.features.json.* 8 | import io.ktor.client.features.json.serializer.* 9 | import io.ktor.client.features.logging.* 10 | 11 | interface PostsService { 12 | 13 | suspend fun getPosts(): List 14 | 15 | suspend fun createPost(postRequest: PostRequest): PostResponse? 16 | 17 | companion object { 18 | fun create(): PostsService { 19 | return PostsServiceImpl( 20 | client = HttpClient(Android) { 21 | install(Logging) { 22 | level = LogLevel.ALL 23 | } 24 | install(JsonFeature) { 25 | serializer = KotlinxSerializer() 26 | } 27 | } 28 | ) 29 | } 30 | } 31 | } -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/data/remote/PostsServiceImpl.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.data.remote 2 | 3 | import com.plcoding.ktorclientandroid.data.remote.dto.PostRequest 4 | import com.plcoding.ktorclientandroid.data.remote.dto.PostResponse 5 | import io.ktor.client.* 6 | import io.ktor.client.features.* 7 | import io.ktor.client.request.* 8 | import io.ktor.http.* 9 | 10 | class PostsServiceImpl( 11 | private val client: HttpClient 12 | ) : PostsService { 13 | 14 | override suspend fun getPosts(): List { 15 | return try { 16 | client.get { url(HttpRoutes.POSTS) } 17 | } catch(e: RedirectResponseException) { 18 | // 3xx - responses 19 | println("Error: ${e.response.status.description}") 20 | emptyList() 21 | } catch(e: ClientRequestException) { 22 | // 4xx - responses 23 | println("Error: ${e.response.status.description}") 24 | emptyList() 25 | } catch(e: ServerResponseException) { 26 | // 5xx - responses 27 | println("Error: ${e.response.status.description}") 28 | emptyList() 29 | } catch(e: Exception) { 30 | println("Error: ${e.message}") 31 | emptyList() 32 | } 33 | } 34 | 35 | override suspend fun createPost(postRequest: PostRequest): PostResponse? { 36 | return try { 37 | client.post { 38 | url(HttpRoutes.POSTS) 39 | contentType(ContentType.Application.Json) 40 | body = postRequest 41 | } 42 | } catch(e: RedirectResponseException) { 43 | // 3xx - responses 44 | println("Error: ${e.response.status.description}") 45 | null 46 | } catch(e: ClientRequestException) { 47 | // 4xx - responses 48 | println("Error: ${e.response.status.description}") 49 | null 50 | } catch(e: ServerResponseException) { 51 | // 5xx - responses 52 | println("Error: ${e.response.status.description}") 53 | null 54 | } catch(e: Exception) { 55 | println("Error: ${e.message}") 56 | null 57 | } 58 | } 59 | } -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/data/remote/dto/PostRequest.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.data.remote.dto 2 | 3 | import kotlinx.serialization.Serializable 4 | 5 | @Serializable 6 | data class PostRequest( 7 | val body: String, 8 | val title: String, 9 | val userId: Int 10 | ) 11 | -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/data/remote/dto/PostResponse.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.data.remote.dto 2 | 3 | import kotlinx.serialization.Serializable 4 | 5 | @Serializable 6 | data class PostResponse( 7 | val body: String, 8 | val title: String, 9 | val id: Int, 10 | val userId: Int 11 | ) 12 | -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/ui/theme/Color.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.ui.theme 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) -------------------------------------------------------------------------------- /app/src/main/java/com/plcoding/ktorclientandroid/ui/theme/Shape.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.ui.theme 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/java/com/plcoding/ktorclientandroid/ui/theme/Theme.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.ui.theme 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 KtorClientAndroidTheme(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/java/com/plcoding/ktorclientandroid/ui/theme/Type.kt: -------------------------------------------------------------------------------- 1 | package com.plcoding.ktorclientandroid.ui.theme 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/res/drawable-v24/ic_launcher_foreground.xml: -------------------------------------------------------------------------------- 1 | 7 | 8 | 9 | 15 | 18 | 21 | 22 | 23 | 24 | 30 | -------------------------------------------------------------------------------- /app/src/main/res/drawable/ic_launcher_background.xml: -------------------------------------------------------------------------------- 1 | 2 | 7 | 10 | 15 | 20 | 25 | 30 | 35 | 40 | 45 | 50 | 55 | 60 | 65 | 70 | 75 | 80 | 85 | 90 | 95 | 100 | 105 | 110 | 115 | 120 | 125 | 130 | 135 | 140 | 145 | 150 | 155 | 160 | 165 | 170 | 171 | -------------------------------------------------------------------------------- /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/res/mipmap-hdpi/ic_launcher.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-hdpi/ic_launcher.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-hdpi/ic_launcher_round.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-mdpi/ic_launcher.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-mdpi/ic_launcher.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-mdpi/ic_launcher_round.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xhdpi/ic_launcher.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-xhdpi/ic_launcher.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxhdpi/ic_launcher.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/philipplackner/KtorClientAndroid/a211b8bb4c1bace9fc3b0fd0d8535cf08b71948f/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp -------------------------------------------------------------------------------- /app/src/main/res/values-night/themes.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 16 | -------------------------------------------------------------------------------- /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/main/res/values/strings.xml: -------------------------------------------------------------------------------- 1 | 2 | KtorClientAndroid 3 | -------------------------------------------------------------------------------- /app/src/main/res/values/themes.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 16 | 17 | 21 | 22 |