day2_commit_11_MEGAFIX
This commit is contained in:
parent
85a5c82d8c
commit
c5be8a2114
@ -43,6 +43,10 @@ dependencies {
|
|||||||
implementation ("com.github.bumptech.glide:glide:4.15.1")
|
implementation ("com.github.bumptech.glide:glide:4.15.1")
|
||||||
kapt ("com.github.bumptech.glide:compiler: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()
|
defaultLibrary()
|
||||||
|
|
||||||
implementation(Dependencies.AndroidX.activity)
|
implementation(Dependencies.AndroidX.activity)
|
||||||
|
@ -11,8 +11,8 @@ interface ApiService {
|
|||||||
@GET("api/{login}/auth")
|
@GET("api/{login}/auth")
|
||||||
suspend fun authenticate(
|
suspend fun authenticate(
|
||||||
@Path("login") login: String,
|
@Path("login") login: String,
|
||||||
@Header("Authorization") authorization: String
|
@Header("Authorization") authorization: String // Добавляем заголовок Authorization
|
||||||
): Response<UserAuthResponse> // Изменяем на UserAuthResponse
|
): Response<UserAuthResponse> // Возвращаем UserAuthResponse
|
||||||
|
|
||||||
@GET("api/{login}/info")
|
@GET("api/{login}/info")
|
||||||
suspend fun getUserInfo(@Path("login") login: String): Response<Map<String, Any>>
|
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>
|
suspend fun getEmployeeInfo(@Path("login") login: String): Response<EmployeeData>
|
||||||
}
|
}
|
||||||
|
|
||||||
// Модель данных для ответа аутентификации
|
|
||||||
data class UserAuthResponse(
|
|
||||||
val role: String // Добавляем поле для роли
|
|
||||||
)
|
|
||||||
|
|
||||||
// Модель данных для информации о сотруднике
|
// Модель данных для информации о сотруднике
|
||||||
data class EmployeeData(
|
data class EmployeeData(
|
||||||
val name: String,
|
val name: String,
|
||||||
@ -41,4 +36,9 @@ data class EmployeeData(
|
|||||||
data class ToggleAccessRequest(
|
data class ToggleAccessRequest(
|
||||||
val login: String,
|
val login: String,
|
||||||
val action: String // "block" или "unblock"
|
val action: String // "block" или "unblock"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Модель данных для ответа аутентификации
|
||||||
|
data class UserAuthResponse(
|
||||||
|
val role: String // Добавляем поле для роли
|
||||||
)
|
)
|
@ -59,6 +59,7 @@ class LoginFragment : Fragment(R.layout.fragment_login) {
|
|||||||
performLogin(username, password) // Передаем пароль в метод performLogin
|
performLogin(username, password) // Передаем пароль в метод performLogin
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Изначально скрываем индикаторы
|
||||||
binding.loading.visibleOrGone(false)
|
binding.loading.visibleOrGone(false)
|
||||||
binding.error.visibleOrGone(false)
|
binding.error.visibleOrGone(false)
|
||||||
}
|
}
|
||||||
|
24
app/src/main/java/utils/Extensions.kt
Normal file
24
app/src/main/java/utils/Extensions.kt
Normal 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
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user