SNM
SNM

Reputation: 6785

RecyclerView inside RecyclerView displaying wrong data

I have an adapter that holds another recyclerview inside, when I load data to this adapter I also load the data for the inner adapter , it is populated but is not populated correctly, when I scroll it populates the items (also wrongly) but when inflated not

class OrdersAdapter(private val context: Context) :
    RecyclerView.Adapter<BaseViewHolder<*>>() {

    private val innerAdapter by lazy { OrdersInnerAdapter(context) }

    ...

     inner class MainViewHolder(itemView: View) : BaseViewHolder<Order>(itemView) {
            override fun bind(item: Order, position: Int) {

                itemView.user_name.text = item.userName

                itemView.rv_order_items.layoutManager = LinearLayoutManager(context)
                itemView.rv_order_items.adapter = innerAdapter
                innerAdapter.setItems(item.cartList)

    }

Now this is my inner adapter

class OrdersInnerAdapter(val context: Context):RecyclerView.Adapter<BaseViewHolder<*>>(){

    private var cartList = mutableListOf<Cart>()

 fun setItems(cartList:MutableList<Cart>){
        this.cartList = cartList
        notifyDataSetChanged()
    } 

 ....

  inner class OrdersInnerViewHolder(itemView: View):BaseViewHolder<Cart>(itemView){
        override fun bind(item: Cart, position: Int) {
            itemView.item_name.text = item.productName
            itemView.item_qty.text = "Quantity: ${item.qty}"
            itemView.item_price.text = "$${item.price.times(item.qty)}.00"
        }
    }

This is my use case

enter image description here

But items inside the inner adapter are loaded wrongly, any idea?

Upvotes: 0

Views: 80

Answers (1)

Atiq
Atiq

Reputation: 14825

class OrdersAdapter(private val context: Context) :
RecyclerView.Adapter<BaseViewHolder<*>>() {

 inner class MainViewHolder(itemView: View) : BaseViewHolder<Order>(itemView) {
        override fun bind(item: Order, position: Int) {

            itemView.user_name.text = item.userName

            itemView.rv_order_items.layoutManager = LinearLayoutManager(context)
            val innerAdapter = OrdersInnerAdapter(context)
            itemView.rv_order_items.adapter = innerAdapter
            innerAdapter.setItems(item.cartList)

}

And you don't need notifyDataSetChanged() in setItems of OrdersInnerAdapter. It would be

fun setItems(cartList:MutableList<Cart>){
    this.cartList = cartList // You can also move this to constructor to get rid of extra method.
} 

Upvotes: 1

Related Questions