Просмотр привязки с помощью EpoxyModelWithHolder
я использую
EpoxyModelWithHolder
с несколькими макетами в одном классе модели Epoxy. Как я могу сделать ViewBinding? В настоящее время я использую
Kotlin-android-extensions
. Ниже мой код
@EpoxyModelClass
abstract class ItemSampleEpoxyModel : EpoxyModelWithHolder() {
@EpoxyAttribute
var itemSampleShelf: ComponentFactoryLanderPagesHeroShelf.ComponentLanderPageHeroShelf.ItemLanderPageHeroShelf? =
null
override fun getDefaultLayout() =
when {
itemSampleShelf?.heroStyle == "Project" -> {
R.layout.item_project_sample
}
itemSampleShelf?.shelfItemType == "Course" -> {
R.layout.item_course_sample
}
else -> {
R.layout.item_sample
}
}
override fun bind(itemHolder: ItemSampleEpoxyHolder) {
itemHolder.titleView.text = itemSampleShelf?.title
} }
class ItemSampleEpoxyHolder : EpoxyHolder() {
lateinit var titleView: AppCompatTextView
override fun bindView(itemView: View) {
titleView = itemView.tv_title
}}
1 ответ
Сначала добавьте зависимость эпоксидной смолы:
def epoxyVersion = '4.6.3'
implementation "com.airbnb.android:epoxy:$epoxyVersion"
implementation "com.airbnb.android:epoxy-databinding:$epoxyVersion"
kapt "com.airbnb.android:epoxy-processor:$epoxyVersion"
После этого нам нужно настроить epoxy. Для этого нам нужно создать файл package-info.java внутри модуля приложения и написать приведенный ниже код.
@EpoxyDataBindingPattern(rClass = R.class, layoutPrefix = "epoxy_item")
interface Config {
}
Затем нам нужно помнить одну вещь : всякий раз, когда мы создаем макет, он должен быть
data binding layout
и его имя должно следовать за значением, определенным в
layoutPrefix
переменная в
package-info
например, в моем случае layoutPrefix таков, когда я называю макет, он начинается с
epoxy_item
.
Образец макета: (Имя макета -> epoxy_item_loading)
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<data>
<variable
name="isVisible"
type="Boolean" />
</data>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:isVisible="@{isVisible}">
<ProgressBar
android:layout_width="20dp"
android:layout_height="20dp"
android:layout_marginTop="10dp"
android:layout_marginBottom="10dp"
android:theme="@style/ProgressBlueTheme"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
</layout>
Теперь, чтобы добавить этот макет в представление переработчика эпоксидной смолы:
epoxyRecycler.withModels {
loading {
id("progress layout")
isVisible(isLoading)// boolean variable
}
}
Это все, что нам нужно сделать :)