/* Copyright 2021 Tusky Contributors * * This file is a part of Tusky. * * This program is free software; you can redistribute it and/or modify it under the terms of the * GNU General Public License as published by the Free Software Foundation; either version 3 of the * License, or (at your option) any later version. * * Tusky is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even * the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General * Public License for more details. * * You should have received a copy of the GNU General Public License along with Tusky; if not, * see . */ package com.keylesspalace.tusky.adapter import android.view.LayoutInflater import android.view.ViewGroup import androidx.recyclerview.widget.RecyclerView import com.keylesspalace.tusky.R import com.keylesspalace.tusky.interfaces.StatusActionListener import com.keylesspalace.tusky.util.StatusDisplayOptions import com.keylesspalace.tusky.viewdata.StatusViewData class ThreadAdapter( private val statusDisplayOptions: StatusDisplayOptions, private val statusActionListener: StatusActionListener ) : RecyclerView.Adapter() { private val statuses = mutableListOf() var detailedStatusPosition: Int = RecyclerView.NO_POSITION private set override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): StatusBaseViewHolder { return when (viewType) { VIEW_TYPE_STATUS -> { val view = LayoutInflater.from(parent.context) .inflate(R.layout.item_status, parent, false) StatusViewHolder(view) } VIEW_TYPE_STATUS_DETAILED -> { val view = LayoutInflater.from(parent.context) .inflate(R.layout.item_status_detailed, parent, false) StatusDetailedViewHolder(view) } else -> error("Unknown item type: $viewType") } } override fun onBindViewHolder(viewHolder: StatusBaseViewHolder, position: Int) { val status = statuses[position] viewHolder.setupWithStatus(status, statusActionListener, statusDisplayOptions) } override fun getItemViewType(position: Int): Int { return if (position == detailedStatusPosition) { VIEW_TYPE_STATUS_DETAILED } else { VIEW_TYPE_STATUS } } override fun getItemCount(): Int = statuses.size fun setStatuses(statuses: List?) { this.statuses.clear() this.statuses.addAll(statuses!!) notifyDataSetChanged() } fun addItem(position: Int, statusViewData: StatusViewData.Concrete) { statuses.add(position, statusViewData) notifyItemInserted(position) } fun clearItems() { val oldSize = statuses.size statuses.clear() detailedStatusPosition = RecyclerView.NO_POSITION notifyItemRangeRemoved(0, oldSize) } fun addAll(position: Int, statuses: List) { this.statuses.addAll(position, statuses) notifyItemRangeInserted(position, statuses.size) } fun addAll(statuses: List) { val end = statuses.size this.statuses.addAll(statuses) notifyItemRangeInserted(end, statuses.size) } fun removeItem(position: Int) { statuses.removeAt(position) notifyItemRemoved(position) } fun clear() { statuses.clear() detailedStatusPosition = RecyclerView.NO_POSITION notifyDataSetChanged() } fun setItem(position: Int, status: StatusViewData.Concrete, notifyAdapter: Boolean) { statuses[position] = status if (notifyAdapter) { notifyItemChanged(position) } } fun getItem(position: Int): StatusViewData.Concrete? = statuses.getOrNull(position) fun setDetailedStatusPosition(position: Int) { if (position != detailedStatusPosition && detailedStatusPosition != RecyclerView.NO_POSITION ) { val prior = detailedStatusPosition detailedStatusPosition = position notifyItemChanged(prior) } else { detailedStatusPosition = position } } companion object { private const val VIEW_TYPE_STATUS = 0 private const val VIEW_TYPE_STATUS_DETAILED = 1 } }