day2_commit_11_MEGAFIX

This commit is contained in:
Terebov_Maksim 2025-02-19 14:36:58 +03:00
parent 85a5c82d8c
commit c5be8a2114
4 changed files with 36 additions and 7 deletions

View File

@ -43,6 +43,10 @@ dependencies {
implementation ("com.github.bumptech.glide:glide:4.15.1")
kapt ("com.github.bumptech.glide:compiler:4.15.1")
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:1.6.0")
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-android:1.6.0")
implementation("androidx.lifecycle:lifecycle-runtime-ktx:2.5.1")
defaultLibrary()
implementation(Dependencies.AndroidX.activity)

View File

@ -11,8 +11,8 @@ interface ApiService {
@GET("api/{login}/auth")
suspend fun authenticate(
@Path("login") login: String,
@Header("Authorization") authorization: String
): Response<UserAuthResponse> // Изменяем на UserAuthResponse
@Header("Authorization") authorization: String // Добавляем заголовок Authorization
): Response<UserAuthResponse> // Возвращаем UserAuthResponse
@GET("api/{login}/info")
suspend fun getUserInfo(@Path("login") login: String): Response<Map<String, Any>>
@ -25,11 +25,6 @@ interface ApiService {
suspend fun getEmployeeInfo(@Path("login") login: String): Response<EmployeeData>
}
// Модель данных для ответа аутентификации
data class UserAuthResponse(
val role: String // Добавляем поле для роли
)
// Модель данных для информации о сотруднике
data class EmployeeData(
val name: String,
@ -41,4 +36,9 @@ data class EmployeeData(
data class ToggleAccessRequest(
val login: String,
val action: String // "block" или "unblock"
)
// Модель данных для ответа аутентификации
data class UserAuthResponse(
val role: String // Добавляем поле для роли
)

View File

@ -59,6 +59,7 @@ class LoginFragment : Fragment(R.layout.fragment_login) {
performLogin(username, password) // Передаем пароль в метод performLogin
}
// Изначально скрываем индикаторы
binding.loading.visibleOrGone(false)
binding.error.visibleOrGone(false)
}

View File

@ -0,0 +1,24 @@
package ru.myitschool.work.utils
import android.view.View
import androidx.lifecycle.Lifecycle
import androidx.lifecycle.LifecycleOwner
import androidx.lifecycle.lifecycleScope
import androidx.lifecycle.repeatOnLifecycle
import kotlinx.coroutines.flow.Flow
import kotlinx.coroutines.flow.collect
import kotlinx.coroutines.launch
// Функция для сбора данных из Flow, когда жизненный цикл находится в состоянии STARTED
fun <T> Flow<T>.collectWhenStarted(lifecycleOwner: LifecycleOwner, collector: (T) -> Unit) {
lifecycleOwner.lifecycleScope.launch {
lifecycleOwner.lifecycle.repeatOnLifecycle(Lifecycle.State.STARTED) {
collect { value -> collector(value) }
}
}
}
// Функция для управления видимостью View
fun View?.visibleOrGone(isVisible: Boolean) {
this?.visibility = if (isVisible) View.VISIBLE else View.GONE
}