Обновление LiveData не вызывает перекомпоновкуAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Обновление LiveData не вызывает перекомпоновку

Сообщение Anonymous »

Я разрабатываю приложение для Android, которое в viewModel обновляет ответ на вход LiveData.

В моей основной активности я наблюдаю за этой переменной с помощью функции ObserveAsState. Однако когда я обновляю значение в своей модели представления, метод LoginScreen не запускается.
Что может быть не так? Разве метод ObserveAsState, когда он получает новое значение, не должен инициировать рекомпозицию LoginScreen?
Вот соответствующий код:
doctorViewModel и mainActivity:
// LiveData for login response
private val _loginResponse = MutableLiveData(null)
val loginResponse: LiveData get() = _loginResponse

suspend fun login(email: String, password: String): String? {
return withContext(Dispatchers.IO) {
try {
val LoginRequest = LoginRequest(email , password)
val response = repository.login(email , password = password)
println("login method : ${response}")
_loginResponse.value = response
invokeAuthToken = true
invokeLoginScreen = true
response
// // Retrofit makes the network call in the background thread
// if (response.isSuccessful) {
// response.body() // the JWT token string
// } else {
// null
// }

} catch (e: Exception) {
null
}
}
}

val loginResponse by viewModel.loginResponse.observeAsState()

if ((viewModel.loginResponse != null)&& (openUserLoginScreen)) {
LoginScreen(
viewModel = viewModel
)
}
if (openUserLoginScreen) {
LoginPopup(
userName = userName,
password = userPassword,
onDismiss = {
viewModel.openUserLoginScreen = false
if (viewModel.loginIconClicked == false) {
viewModel.loginIconClicked = false
}
if (viewModel.logOutIconClicked == true) {
viewModel.logOutIconClicked = false
viewModel.loginIconClicked = false
}
},
viewModel = viewModel)
}

@Composable
fun LoginScreen(
viewModel: DoctorViewModel,
) {
println("LoginScreen COMPOSED")

val loginResponse = viewModel.loginResponse.value
val loginError = viewModel.loginError.observeAsState()
println("LoginScreen : ${loginResponse}")

// SUCCESS ---------------------------------------------------------
LaunchedEffect(loginResponse) {
loginResponse?.let { token ->
println("LoginScreen: Received login token = $token")

viewModel.setOwnAuthToken(token)
viewModel.setOwnInvokeAuthToken(false)
viewModel.setOwnGetUserDetails(true)
viewModel.setOwnUserLoginCompleted(true)
viewModel.setOwnOpenUserLoginScreen(false)
}
}

// FAILURE ---------------------------------------------------------
LaunchedEffect(loginError.value) {
loginError.value?.let { error ->
println("LoginScreen: Login error = $error")

viewModel.setOwnOpenUserLoginScreen(true)
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/798 ... compostion
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»