|
|
@ -7,15 +7,16 @@ import org.session.libsession.messaging.threads.Address
|
|
|
|
import org.thoughtcrime.securesms.loki.views.UserView
|
|
|
|
import org.thoughtcrime.securesms.loki.views.UserView
|
|
|
|
import org.thoughtcrime.securesms.mms.GlideRequests
|
|
|
|
import org.thoughtcrime.securesms.mms.GlideRequests
|
|
|
|
import org.session.libsession.messaging.threads.recipients.Recipient
|
|
|
|
import org.session.libsession.messaging.threads.recipients.Recipient
|
|
|
|
|
|
|
|
import org.session.libsession.utilities.TextSecurePreferences
|
|
|
|
|
|
|
|
|
|
|
|
class EditClosedGroupMembersAdapter(
|
|
|
|
class EditClosedGroupMembersAdapter(
|
|
|
|
private val context: Context,
|
|
|
|
private val context: Context,
|
|
|
|
private val glide: GlideRequests,
|
|
|
|
private val glide: GlideRequests,
|
|
|
|
|
|
|
|
private val admin: Boolean,
|
|
|
|
private val memberClickListener: ((String) -> Unit)? = null
|
|
|
|
private val memberClickListener: ((String) -> Unit)? = null
|
|
|
|
) : RecyclerView.Adapter<EditClosedGroupMembersAdapter.ViewHolder>() {
|
|
|
|
) : RecyclerView.Adapter<EditClosedGroupMembersAdapter.ViewHolder>() {
|
|
|
|
|
|
|
|
|
|
|
|
private val members = ArrayList<String>()
|
|
|
|
private val members = ArrayList<String>()
|
|
|
|
private val lockedMembers = HashSet<String>()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setMembers(members: Collection<String>) {
|
|
|
|
fun setMembers(members: Collection<String>) {
|
|
|
|
this.members.clear()
|
|
|
|
this.members.clear()
|
|
|
@ -23,12 +24,6 @@ class EditClosedGroupMembersAdapter(
|
|
|
|
notifyDataSetChanged()
|
|
|
|
notifyDataSetChanged()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fun setLockedMembers(members: Collection<String>) {
|
|
|
|
|
|
|
|
this.lockedMembers.clear()
|
|
|
|
|
|
|
|
this.lockedMembers.addAll(members)
|
|
|
|
|
|
|
|
notifyDataSetChanged()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
override fun getItemCount(): Int = members.size
|
|
|
|
override fun getItemCount(): Int = members.size
|
|
|
|
|
|
|
|
|
|
|
|
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
|
|
|
|
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
|
|
|
@ -39,15 +34,15 @@ class EditClosedGroupMembersAdapter(
|
|
|
|
override fun onBindViewHolder(viewHolder: ViewHolder, position: Int) {
|
|
|
|
override fun onBindViewHolder(viewHolder: ViewHolder, position: Int) {
|
|
|
|
val member = members[position]
|
|
|
|
val member = members[position]
|
|
|
|
|
|
|
|
|
|
|
|
val lockedMember = lockedMembers.contains(member)
|
|
|
|
val unlocked = admin && member != TextSecurePreferences.getLocalNumber(context)
|
|
|
|
|
|
|
|
|
|
|
|
viewHolder.view.bind(Recipient.from(
|
|
|
|
viewHolder.view.bind(Recipient.from(
|
|
|
|
context,
|
|
|
|
context,
|
|
|
|
Address.fromSerialized(member), false),
|
|
|
|
Address.fromSerialized(member), false),
|
|
|
|
glide,
|
|
|
|
glide,
|
|
|
|
if (lockedMember) UserView.ActionIndicator.None else UserView.ActionIndicator.Menu)
|
|
|
|
if (unlocked) UserView.ActionIndicator.Menu else UserView.ActionIndicator.None)
|
|
|
|
|
|
|
|
|
|
|
|
if (!lockedMember) {
|
|
|
|
if (unlocked) {
|
|
|
|
viewHolder.view.setOnClickListener { this.memberClickListener?.invoke(member) }
|
|
|
|
viewHolder.view.setOnClickListener { this.memberClickListener?.invoke(member) }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|