|
|
@ -30,12 +30,12 @@ abstract class TabsAdapter<T : TabViewHolder>(
|
|
|
|
delegate: Observable<TabsTray.Observer> = ObserverRegistry()
|
|
|
|
delegate: Observable<TabsTray.Observer> = ObserverRegistry()
|
|
|
|
) : ListAdapter<Tab, T>(DiffCallback), TabsTray, Observable<TabsTray.Observer> by delegate {
|
|
|
|
) : ListAdapter<Tab, T>(DiffCallback), TabsTray, Observable<TabsTray.Observer> by delegate {
|
|
|
|
|
|
|
|
|
|
|
|
protected var tabs: Tabs? = null
|
|
|
|
protected var selectedIndex: Int? = null
|
|
|
|
protected var styling: TabsTrayStyling = TabsTrayStyling()
|
|
|
|
protected var styling: TabsTrayStyling = TabsTrayStyling()
|
|
|
|
|
|
|
|
|
|
|
|
@CallSuper
|
|
|
|
@CallSuper
|
|
|
|
override fun updateTabs(tabs: Tabs) {
|
|
|
|
override fun updateTabs(tabs: Tabs) {
|
|
|
|
this.tabs = tabs
|
|
|
|
this.selectedIndex = tabs.selectedIndex
|
|
|
|
|
|
|
|
|
|
|
|
submitList(tabs.list)
|
|
|
|
submitList(tabs.list)
|
|
|
|
|
|
|
|
|
|
|
@ -44,13 +44,10 @@ abstract class TabsAdapter<T : TabViewHolder>(
|
|
|
|
|
|
|
|
|
|
|
|
@CallSuper
|
|
|
|
@CallSuper
|
|
|
|
override fun onBindViewHolder(holder: T, position: Int) {
|
|
|
|
override fun onBindViewHolder(holder: T, position: Int) {
|
|
|
|
val tabs = tabs ?: return
|
|
|
|
holder.bind(getItem(position), selectedIndex == position, styling, this)
|
|
|
|
|
|
|
|
|
|
|
|
holder.bind(tabs.list[position], isTabSelected(tabs, position), styling, this)
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
final override fun isTabSelected(tabs: Tabs, position: Int): Boolean =
|
|
|
|
override fun isTabSelected(tabs: Tabs, position: Int): Boolean = false
|
|
|
|
tabs.selectedIndex == position
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private object DiffCallback : DiffUtil.ItemCallback<Tab>() {
|
|
|
|
private object DiffCallback : DiffUtil.ItemCallback<Tab>() {
|
|
|
|
override fun areItemsTheSame(oldItem: Tab, newItem: Tab): Boolean {
|
|
|
|
override fun areItemsTheSame(oldItem: Tab, newItem: Tab): Boolean {
|
|
|
|