JetPack Compose: Государственное управлениеAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 JetPack Compose: Государственное управление

Сообщение Anonymous »

Я работал над функцией чата в своем приложении, и я использовал чистую архитектуру и создаю вариант использования, хранилище состояния пользовательского интерфейса и моделях просмотра. Но я изо всех сил пытаюсь вызвать переоборудование по функции удаления.
Я знаю, что это долгий вопрос, но я написал его, чтобы кратко описать проблему, это легко понять.data class ChatScreenState(
val isLoading: Boolean = false,
val error: String? = null, // Null means no error
val data: ChatScreenData? = null
)
< /code>
и класс данных, содержащих данные,: < /p>
data class ChatScreenData(
val productId : String = ",
val productTitle : String = ",
var chat : List,
)

//this is the data class to hold chat list
data class ChatItemData(
val id : String = UUID.randomUUID().toString(),
val message: String = "",
)

// dummy data to check
object SampleData{
val ChatScreenDataList = mutableListOf(
ChatScreenData("1", "book" , listOf(ChatItemData("hello"), ChatItemData("hi"), ChatItemData("how are you?"))),
)
}
< /code>
my composable < /p>
@Composable
fun ChatScreen(
productId : String,
viewModel: ChatScreenViewModel = hiltViewModel()
) {
val uiState by viewModel.uiState.collectAsStateWithLifecycle()
// this ui state has Loading, error and data state

// i have handle other states

if(uiState.data != null){
LazyColumn{
itemsIndexed(items = uiState.data!!.chat, key = {_, item -> item.id}) { index, item ->
Column {
Text(item.message)
Icon(
imageVector = Icons.Default.Delete,
contentDescription = null,
modifier = Modifier.clickable {
viewModel.deleteChatItemData()
}
)
}
}
}
}
< /code>
Модель моего представления: < /p>
@HiltViewModel
class ChatScreenViewModel @Inject constructor(
private val chatRepository: ChatRepository
):ViewModel() {
private val _uiState = MutableStateFlow(ChatScreenState())
val uiState = _uiState.asStateFlow()

fun deleteChatItemData(productId: String, chatItemData: ChatItemData){
viewModelScope.launch {
chatRepository.deleteChatItemData(productId, chatItemData)
}
_uiState.update {currentState ->
currentState.copy(
data = currentState.data!!.copy(chat = currentState.data.chat - chatItemData )
)
}
}
}
< /code>
Репозиторий: < /p>
suspend fun deleteChatItemData(productId: String, chatItemData: ChatItemData) {

if(ChatScreenDataList.find { it.productId==productId }!=null) {
ChatScreenDataList.find { it.productId == productId }!!.chat -= chatItemData

}
}
< /code>
В репозитории я использовал пример списка, который хранится в объекте.ChatScreenDataList.find { it.productId == productId }!!.chat -= chatItemData
< /code>
В репозитории он работает правильно, и не удалит элемент из списка в списке, но правильно решает. Я не могу понять, что такое соединение, и как я могу это исправить?

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

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

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

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

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

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