Mention List View
MentionListView
is a UI Component that shows previews of messages that contain mentions of the current user.
Light Mode | Dark Mode |
---|---|
Usage
You can add this View via XML:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<io.getstream.chat.android.ui.mention.list.MentionListView
android:id="@+id/mentionsListView"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
/>
</androidx.constraintlayout.widget.ConstraintLayout>
We recommend using this view with its ViewModel, which supplies it with data from the Stream API.
The basic setup of the ViewModel and connecting it to the View is done the following way:
- Kotlin
- Java
val viewModel: MentionListViewModel by viewModels()
viewModel.bindView(mentionListView, viewLifecycleOwner)
MentionListViewModel viewModel = new ViewModelProvider(this).get(MentionListViewModel.class);
MentionListViewModelBinding.bind(viewModel, mentionListView, getViewLifecycleOwner());
From that point, you should be able to see messages which contain mentions of the current user.
note
bindView
sets listeners on the View and the ViewModel. Any additional listeners should be set after calling bindView
.
Handling Actions
MentionListView
allows you to configure certain actions on it:
- Kotlin
- Java
mentionListView.setMentionSelectedListener { message ->
// Handle a mention item being clicked
}
mentionListView.setMentionSelectedListener(message -> {
// Handle a mention item being clicked
});
The full list of available listeners is available here.