commit d26e08476b986b724b84e90743042163664b3055 Author: Your Name Date: Thu Feb 13 19:26:51 2025 +0300 get_user;ge_massive_with_users diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..aa724b7 --- /dev/null +++ b/.gitignore @@ -0,0 +1,15 @@ +*.iml +.gradle +/local.properties +/.idea/caches +/.idea/libraries +/.idea/modules.xml +/.idea/workspace.xml +/.idea/navEditor.xml +/.idea/assetWizardSettings.xml +.DS_Store +/build +/captures +.externalNativeBuild +.cxx +local.properties diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..26d3352 --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,3 @@ +# Default ignored files +/shelf/ +/workspace.xml diff --git a/.idea/.name b/.idea/.name new file mode 100644 index 0000000..26039cd --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +testKtor \ No newline at end of file diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..b86273d --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/deploymentTargetSelector.xml b/.idea/deploymentTargetSelector.xml new file mode 100644 index 0000000..b268ef3 --- /dev/null +++ b/.idea/deploymentTargetSelector.xml @@ -0,0 +1,10 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..7b3006b --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,20 @@ + + + + + + + \ No newline at end of file diff --git a/.idea/inspectionProfiles/Project_Default.xml b/.idea/inspectionProfiles/Project_Default.xml new file mode 100644 index 0000000..cde3e19 --- /dev/null +++ b/.idea/inspectionProfiles/Project_Default.xml @@ -0,0 +1,57 @@ + + + + \ No newline at end of file diff --git a/.idea/kotlinc.xml b/.idea/kotlinc.xml new file mode 100644 index 0000000..6d0ee1c --- /dev/null +++ b/.idea/kotlinc.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/.idea/migrations.xml b/.idea/migrations.xml new file mode 100644 index 0000000..f8051a6 --- /dev/null +++ b/.idea/migrations.xml @@ -0,0 +1,10 @@ + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..74dd639 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,10 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/runConfigurations.xml b/.idea/runConfigurations.xml new file mode 100644 index 0000000..16660f1 --- /dev/null +++ b/.idea/runConfigurations.xml @@ -0,0 +1,17 @@ + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..d843f34 --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..42afabf --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build \ No newline at end of file diff --git a/app/build.gradle.kts b/app/build.gradle.kts new file mode 100644 index 0000000..5e830da --- /dev/null +++ b/app/build.gradle.kts @@ -0,0 +1,69 @@ +plugins { + id("org.jetbrains.kotlin.plugin.serialization") version "1.8.21" // Обновите если необходимо + id("kotlin-android") + alias(libs.plugins.android.application) + alias(libs.plugins.kotlin.android) + alias(libs.plugins.kotlin.compose) +} + +android { + namespace = "com.example.testktor" + compileSdk = 35 + + defaultConfig { + applicationId = "com.example.testktor" + minSdk = 24 + targetSdk = 35 + versionCode = 1 + versionName = "1.0" + + testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" + } + + buildTypes { + release { + isMinifyEnabled = false + proguardFiles( + getDefaultProguardFile("proguard-android-optimize.txt"), + "proguard-rules.pro" + ) + } + } + compileOptions { + sourceCompatibility = JavaVersion.VERSION_11 + targetCompatibility = JavaVersion.VERSION_11 + } + kotlinOptions { + jvmTarget = "11" + } + buildFeatures { + compose = true + } +} + +dependencies { + implementation(libs.androidx.core.ktx) + implementation(libs.androidx.lifecycle.runtime.ktx) + implementation(libs.androidx.activity.compose) + implementation(platform(libs.androidx.compose.bom)) + implementation(libs.androidx.ui) + implementation(libs.androidx.ui.graphics) + implementation(libs.androidx.ui.tooling.preview) + implementation(libs.androidx.material3) + testImplementation(libs.junit) + androidTestImplementation(libs.androidx.junit) + androidTestImplementation(libs.androidx.espresso.core) + androidTestImplementation(platform(libs.androidx.compose.bom)) + androidTestImplementation(libs.androidx.ui.test.junit4) + debugImplementation(libs.androidx.ui.tooling) + debugImplementation(libs.androidx.ui.test.manifest) + + // Ktor dependencies + implementation("io.ktor:ktor-client-core:2.0.0") + implementation("io.ktor:ktor-client-android:2.0.0") + implementation("io.ktor:ktor-client-content-negotiation:2.0.0") + implementation("io.ktor:ktor-serialization-kotlinx-json:2.0.0") + + // Kotlinx serialization dependencies + implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.4.0") +} \ No newline at end of file diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..481bb43 --- /dev/null +++ b/app/proguard-rules.pro @@ -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. +# +# 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 \ No newline at end of file diff --git a/app/src/androidTest/java/com/example/testktor/ExampleInstrumentedTest.kt b/app/src/androidTest/java/com/example/testktor/ExampleInstrumentedTest.kt new file mode 100644 index 0000000..76fd806 --- /dev/null +++ b/app/src/androidTest/java/com/example/testktor/ExampleInstrumentedTest.kt @@ -0,0 +1,24 @@ +package com.example.testktor + +import androidx.test.platform.app.InstrumentationRegistry +import androidx.test.ext.junit.runners.AndroidJUnit4 + +import org.junit.Test +import org.junit.runner.RunWith + +import org.junit.Assert.* + +/** + * Instrumented test, which will execute on an Android device. + * + * See [testing documentation](http://d.android.com/tools/testing). + */ +@RunWith(AndroidJUnit4::class) +class ExampleInstrumentedTest { + @Test + fun useAppContext() { + // Context of the app under test. + val appContext = InstrumentationRegistry.getInstrumentation().targetContext + assertEquals("com.example.testktor", appContext.packageName) + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..7143a22 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,31 @@ + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/java/com/example/testktor/MainActivity.kt b/app/src/main/java/com/example/testktor/MainActivity.kt new file mode 100644 index 0000000..e2e852a --- /dev/null +++ b/app/src/main/java/com/example/testktor/MainActivity.kt @@ -0,0 +1,229 @@ +//package com.example.testktor +// +//import android.os.Bundle +//import android.util.Log +//import androidx.activity.ComponentActivity +//import androidx.activity.compose.setContent +//import androidx.activity.enableEdgeToEdge +//import androidx.compose.foundation.layout.fillMaxSize +//import androidx.compose.foundation.layout.padding +//import androidx.compose.material3.Scaffold +//import androidx.compose.material3.Text +//import androidx.compose.material3.CircularProgressIndicator +//import androidx.compose.runtime.* +//import androidx.compose.ui.Modifier +//import androidx.compose.ui.tooling.preview.Preview +//import com.example.testktor.ui.theme.TestKtorTheme +//import io.ktor.client.* +//import io.ktor.client.request.* +//import io.ktor.client.engine.android.* +//import io.ktor.client.plugins.contentnegotiation.* +//import io.ktor.client.statement.HttpResponse +//import io.ktor.client.statement.bodyAsText +//import io.ktor.http.ContentType +//import io.ktor.http.contentType +//import kotlinx.coroutines.launch +//import kotlinx.serialization.Serializable +//import io.ktor.serialization.kotlinx.json.* +//import kotlinx.serialization.decodeFromString +//import kotlinx.serialization.json.Json +// +//@Serializable +//data class User(val id: Int, val name: String) +// +//class MainActivity : ComponentActivity() { +// private val client = HttpClient(Android) { +// install(ContentNegotiation) { +// json(Json { prettyPrint = true }) +// } +// } +// +// override fun onCreate(savedInstanceState: Bundle?) { +// super.onCreate(savedInstanceState) +// enableEdgeToEdge() +// setContent { +// TestKtorTheme { +// Scaffold(modifier = Modifier.fillMaxSize()) { innerPadding -> +// UserScreen(modifier = Modifier.padding(innerPadding), client = client) +// } +// } +// } +// } +//} +// +//@Composable +//fun UserScreen(modifier: Modifier = Modifier, client: HttpClient) { +// var user by remember { mutableStateOf(null) } +// var isLoading by remember { mutableStateOf(true) } +// var errorMessage by remember { mutableStateOf(null) } +// +// val scope = rememberCoroutineScope() +// +// LaunchedEffect(Unit) { +// try { +// val fetchedUser = getUser(client) // Получаем одного пользователя +// user = fetchedUser +// } catch (e: Exception) { +// errorMessage = "Error fetching user: ${e.localizedMessage}" +// Log.e("UserScreen", "Error: ${e.localizedMessage}", e) +// } +// isLoading = false +// } +// +// if (isLoading) { +// CircularProgressIndicator() +// } +// +// errorMessage?.let { +// Text(text = it) +// } +// +// user?.let { +// Text(text = "User: ${it.name}, ID: ${it.id}") // Отображаем имя пользователя +// } ?: run { +// Text(text = "No user found or failed to load.") +// } +//} +// +//suspend fun getUser(client: HttpClient): User { +// val response: HttpResponse = client.get("http://10.0.2.2:8080/user") { +// contentType(ContentType.Application.Json) +// } +// val responseBody = response.bodyAsText() +// Log.d("getUser", "Response: $responseBody") // Логируем ответ сервера +// +// val json = Json { ignoreUnknownKeys = true } +// +// val buba = json.decodeFromString(responseBody) // Десериализуем в объект User +// Log.d("json", buba.name) +// +// return try { +// json.decodeFromString(responseBody) // Десериализуем в объект User +// } catch (e: Exception) { +// Log.e("getUser", "Error deserializing response", e) +// throw e // Повторно выбрасываем ошибку, чтобы она была обработана в UserScreen +// } +//} +// +//@Preview(showBackground = true) +//@Composable +//fun UserScreenPreview() { +// TestKtorTheme { +// UserScreen(client = HttpClient(Android)) +// } +//} + + +package com.example.testktor + +import android.os.Bundle +import android.util.Log +import androidx.activity.ComponentActivity +import androidx.activity.compose.setContent +import androidx.activity.enableEdgeToEdge +import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.foundation.layout.padding +import androidx.compose.material3.Scaffold +import androidx.compose.material3.Text +import androidx.compose.material3.CircularProgressIndicator +import androidx.compose.runtime.* +import androidx.compose.ui.Modifier +import androidx.compose.ui.tooling.preview.Preview +import com.example.testktor.ui.theme.TestKtorTheme +import io.ktor.client.* +import io.ktor.client.request.* +import io.ktor.client.engine.android.* +import io.ktor.client.plugins.contentnegotiation.* +import io.ktor.client.statement.HttpResponse +import io.ktor.client.statement.bodyAsText +import io.ktor.http.ContentType +import io.ktor.http.contentType +import kotlinx.coroutines.launch +import kotlinx.serialization.Serializable +import io.ktor.serialization.kotlinx.json.* +import kotlinx.serialization.decodeFromString +import kotlinx.serialization.json.Json + +@Serializable +data class User(val id: Int, val name: String) + +class MainActivity : ComponentActivity() { + private val client = HttpClient(Android) { + install(ContentNegotiation) { + json(Json { prettyPrint = true }) + } + } + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + enableEdgeToEdge() + setContent { + TestKtorTheme { + Scaffold(modifier = Modifier.fillMaxSize()) { innerPadding -> + UserScreen(modifier = Modifier.padding(innerPadding), client = client) + } + } + } + } +} + +@Composable +fun UserScreen(modifier: Modifier = Modifier, client: HttpClient) { + var users by remember { mutableStateOf?>(null) } + var isLoading by remember { mutableStateOf(true) } + var errorMessage by remember { mutableStateOf(null) } + + val scope = rememberCoroutineScope() + + LaunchedEffect(Unit) { + try { + val fetchedUsers = getUsers(client) + users = fetchedUsers + } catch (e: Exception) { + errorMessage = "Error fetching users: ${e.localizedMessage}" + Log.e("UserScreen", "Error: ${e.localizedMessage}", e) + } + isLoading = false + } + + if (isLoading) { + CircularProgressIndicator() + } + + errorMessage?.let { + Text(text = it) + } + + users?.let { + it.forEach { user -> + Text(text = "User: ${user.name}, ID: ${user.id}") + } + } ?: run { + Text(text = "No users found or failed to load.") + } +} + +suspend fun getUsers(client: HttpClient): List { + val response: HttpResponse = client.get("http://212.67.10.54:8080/users") { + contentType(ContentType.Application.Json) + } + val responseBody = response.bodyAsText() + Log.d("getUsers", "Response: $responseBody") // Логируем ответ сервера + + val json = Json { ignoreUnknownKeys = true } + + return try { + json.decodeFromString>(responseBody) // Десериализуем в List + } catch (e: Exception) { + Log.e("getUsers", "Error deserializing response", e) + throw e // Повторно выбрасываем ошибку, чтобы она была обработана в UserScreen + } +} + +@Preview(showBackground = true) +@Composable +fun UserScreenPreview() { + TestKtorTheme { + UserScreen(client = HttpClient(Android)) + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/testktor/ui/theme/Color.kt b/app/src/main/java/com/example/testktor/ui/theme/Color.kt new file mode 100644 index 0000000..408f6f7 --- /dev/null +++ b/app/src/main/java/com/example/testktor/ui/theme/Color.kt @@ -0,0 +1,11 @@ +package com.example.testktor.ui.theme + +import androidx.compose.ui.graphics.Color + +val Purple80 = Color(0xFFD0BCFF) +val PurpleGrey80 = Color(0xFFCCC2DC) +val Pink80 = Color(0xFFEFB8C8) + +val Purple40 = Color(0xFF6650a4) +val PurpleGrey40 = Color(0xFF625b71) +val Pink40 = Color(0xFF7D5260) \ No newline at end of file diff --git a/app/src/main/java/com/example/testktor/ui/theme/Theme.kt b/app/src/main/java/com/example/testktor/ui/theme/Theme.kt new file mode 100644 index 0000000..ca05308 --- /dev/null +++ b/app/src/main/java/com/example/testktor/ui/theme/Theme.kt @@ -0,0 +1,58 @@ +package com.example.testktor.ui.theme + +import android.app.Activity +import android.os.Build +import androidx.compose.foundation.isSystemInDarkTheme +import androidx.compose.material3.MaterialTheme +import androidx.compose.material3.darkColorScheme +import androidx.compose.material3.dynamicDarkColorScheme +import androidx.compose.material3.dynamicLightColorScheme +import androidx.compose.material3.lightColorScheme +import androidx.compose.runtime.Composable +import androidx.compose.ui.platform.LocalContext + +private val DarkColorScheme = darkColorScheme( + primary = Purple80, + secondary = PurpleGrey80, + tertiary = Pink80 +) + +private val LightColorScheme = lightColorScheme( + primary = Purple40, + secondary = PurpleGrey40, + tertiary = Pink40 + + /* Other default colors to override + background = Color(0xFFFFFBFE), + surface = Color(0xFFFFFBFE), + onPrimary = Color.White, + onSecondary = Color.White, + onTertiary = Color.White, + onBackground = Color(0xFF1C1B1F), + onSurface = Color(0xFF1C1B1F), + */ +) + +@Composable +fun TestKtorTheme( + darkTheme: Boolean = isSystemInDarkTheme(), + // Dynamic color is available on Android 12+ + dynamicColor: Boolean = true, + content: @Composable () -> Unit +) { + val colorScheme = when { + dynamicColor && Build.VERSION.SDK_INT >= Build.VERSION_CODES.S -> { + val context = LocalContext.current + if (darkTheme) dynamicDarkColorScheme(context) else dynamicLightColorScheme(context) + } + + darkTheme -> DarkColorScheme + else -> LightColorScheme + } + + MaterialTheme( + colorScheme = colorScheme, + typography = Typography, + content = content + ) +} \ No newline at end of file diff --git a/app/src/main/java/com/example/testktor/ui/theme/Type.kt b/app/src/main/java/com/example/testktor/ui/theme/Type.kt new file mode 100644 index 0000000..13ac3c2 --- /dev/null +++ b/app/src/main/java/com/example/testktor/ui/theme/Type.kt @@ -0,0 +1,34 @@ +package com.example.testktor.ui.theme + +import androidx.compose.material3.Typography +import androidx.compose.ui.text.TextStyle +import androidx.compose.ui.text.font.FontFamily +import androidx.compose.ui.text.font.FontWeight +import androidx.compose.ui.unit.sp + +// Set of Material typography styles to start with +val Typography = Typography( + bodyLarge = TextStyle( + fontFamily = FontFamily.Default, + fontWeight = FontWeight.Normal, + fontSize = 16.sp, + lineHeight = 24.sp, + letterSpacing = 0.5.sp + ) + /* Other default text styles to override + titleLarge = TextStyle( + fontFamily = FontFamily.Default, + fontWeight = FontWeight.Normal, + fontSize = 22.sp, + lineHeight = 28.sp, + letterSpacing = 0.sp + ), + labelSmall = TextStyle( + fontFamily = FontFamily.Default, + fontWeight = FontWeight.Medium, + fontSize = 11.sp, + lineHeight = 16.sp, + letterSpacing = 0.5.sp + ) + */ +) \ No newline at end of file diff --git a/app/src/main/res/drawable/ic_launcher_background.xml b/app/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/app/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/drawable/ic_launcher_foreground.xml b/app/src/main/res/drawable/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/app/src/main/res/drawable/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml new file mode 100644 index 0000000..6f3b755 --- /dev/null +++ b/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml new file mode 100644 index 0000000..6f3b755 --- /dev/null +++ b/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/mipmap-hdpi/ic_launcher.webp b/app/src/main/res/mipmap-hdpi/ic_launcher.webp new file mode 100644 index 0000000..c209e78 Binary files /dev/null and b/app/src/main/res/mipmap-hdpi/ic_launcher.webp differ diff --git a/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp b/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp new file mode 100644 index 0000000..b2dfe3d Binary files /dev/null and b/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp differ diff --git a/app/src/main/res/mipmap-mdpi/ic_launcher.webp b/app/src/main/res/mipmap-mdpi/ic_launcher.webp new file mode 100644 index 0000000..4f0f1d6 Binary files /dev/null and b/app/src/main/res/mipmap-mdpi/ic_launcher.webp differ diff --git a/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp b/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp new file mode 100644 index 0000000..62b611d Binary files /dev/null and b/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp differ diff --git a/app/src/main/res/mipmap-xhdpi/ic_launcher.webp b/app/src/main/res/mipmap-xhdpi/ic_launcher.webp new file mode 100644 index 0000000..948a307 Binary files /dev/null and b/app/src/main/res/mipmap-xhdpi/ic_launcher.webp differ diff --git a/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp b/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp new file mode 100644 index 0000000..1b9a695 Binary files /dev/null and b/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp differ diff --git a/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp b/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp new file mode 100644 index 0000000..28d4b77 Binary files /dev/null and b/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp differ diff --git a/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp b/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp new file mode 100644 index 0000000..9287f50 Binary files /dev/null and b/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp differ diff --git a/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp b/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp new file mode 100644 index 0000000..aa7d642 Binary files /dev/null and b/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp differ diff --git a/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp b/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp new file mode 100644 index 0000000..9126ae3 Binary files /dev/null and b/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp differ diff --git a/app/src/main/res/values/colors.xml b/app/src/main/res/values/colors.xml new file mode 100644 index 0000000..f8c6127 --- /dev/null +++ b/app/src/main/res/values/colors.xml @@ -0,0 +1,10 @@ + + + #FFBB86FC + #FF6200EE + #FF3700B3 + #FF03DAC5 + #FF018786 + #FF000000 + #FFFFFFFF + \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml new file mode 100644 index 0000000..33acfac --- /dev/null +++ b/app/src/main/res/values/strings.xml @@ -0,0 +1,3 @@ + + testKtor + \ No newline at end of file diff --git a/app/src/main/res/values/themes.xml b/app/src/main/res/values/themes.xml new file mode 100644 index 0000000..ac3f78a --- /dev/null +++ b/app/src/main/res/values/themes.xml @@ -0,0 +1,5 @@ + + + +