mirror of
https://github.com/oxen-io/session-android.git
synced 2025-02-24 23:17:21 +00:00
Create closed group activity refactoring.
This commit is contained in:
parent
6664c2baa7
commit
15d463161a
@ -63,7 +63,7 @@
|
|||||||
|
|
||||||
<Button
|
<Button
|
||||||
style="@style/MediumProminentOutlineButton"
|
style="@style/MediumProminentOutlineButton"
|
||||||
android:id="@+id/createNewPrivateChatButton"
|
android:id="@+id/btnCreateNewPrivateChat"
|
||||||
android:layout_width="196dp"
|
android:layout_width="196dp"
|
||||||
android:layout_height="@dimen/medium_button_height"
|
android:layout_height="@dimen/medium_button_height"
|
||||||
android:layout_marginTop="@dimen/medium_spacing"
|
android:layout_marginTop="@dimen/medium_spacing"
|
||||||
|
@ -107,7 +107,7 @@
|
|||||||
|
|
||||||
<Button
|
<Button
|
||||||
style="@style/MediumProminentOutlineButton"
|
style="@style/MediumProminentOutlineButton"
|
||||||
android:id="@+id/createNewPrivateChatButton"
|
android:id="@+id/btnCreateNewPrivateChat"
|
||||||
android:layout_width="196dp"
|
android:layout_width="196dp"
|
||||||
android:layout_height="@dimen/medium_button_height"
|
android:layout_height="@dimen/medium_button_height"
|
||||||
android:layout_marginTop="@dimen/medium_spacing"
|
android:layout_marginTop="@dimen/medium_spacing"
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
|
|
||||||
<Button
|
<Button
|
||||||
style="@style/MediumProminentOutlineButton"
|
style="@style/MediumProminentOutlineButton"
|
||||||
android:id="@+id/createNewPrivateChatButton"
|
android:id="@+id/btnCreateNewPrivateChat"
|
||||||
android:layout_width="196dp"
|
android:layout_width="196dp"
|
||||||
android:layout_height="@dimen/medium_button_height"
|
android:layout_height="@dimen/medium_button_height"
|
||||||
android:layout_marginTop="@dimen/medium_spacing"
|
android:layout_marginTop="@dimen/medium_spacing"
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package org.thoughtcrime.securesms.loki.activities
|
package org.thoughtcrime.securesms.loki.activities
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.graphics.Bitmap
|
import android.graphics.Bitmap
|
||||||
import android.os.AsyncTask
|
import android.os.AsyncTask
|
||||||
@ -25,31 +26,29 @@ import org.thoughtcrime.securesms.util.TextSecurePreferences
|
|||||||
import org.whispersystems.libsignal.util.guava.Optional
|
import org.whispersystems.libsignal.util.guava.Optional
|
||||||
import java.lang.ref.WeakReference
|
import java.lang.ref.WeakReference
|
||||||
|
|
||||||
class CreateClosedGroupActivity : PassphraseRequiredActionBarActivity(), MemberClickListener, LoaderManager.LoaderCallbacks<List<String>> {
|
const val RESULT_CODE_CREATE_CLOSED_GROUP = 100
|
||||||
|
|
||||||
|
class CreateClosedGroupActivity : PassphraseRequiredActionBarActivity(), LoaderManager.LoaderCallbacks<List<String>> {
|
||||||
|
|
||||||
|
private lateinit var selectContactsAdapter: SelectContactsAdapter
|
||||||
|
|
||||||
private var members = listOf<String>()
|
private var members = listOf<String>()
|
||||||
set(value) { field = value; createClosedGroupAdapter.members = value }
|
set(value) {
|
||||||
|
field = value
|
||||||
private val createClosedGroupAdapter by lazy {
|
selectContactsAdapter.members = value
|
||||||
val glide = GlideApp.with(this)
|
}
|
||||||
val result = SelectContactsAdapter(this, glide, this)
|
|
||||||
result
|
|
||||||
}
|
|
||||||
|
|
||||||
private val selectedMembers: Set<String>
|
|
||||||
get() { return createClosedGroupAdapter.selectedMembers }
|
|
||||||
|
|
||||||
companion object {
|
|
||||||
public val createNewPrivateChatResultCode = 100
|
|
||||||
}
|
|
||||||
|
|
||||||
// region Lifecycle
|
// region Lifecycle
|
||||||
override fun onCreate(savedInstanceState: Bundle?, isReady: Boolean) {
|
override fun onCreate(savedInstanceState: Bundle?, isReady: Boolean) {
|
||||||
super.onCreate(savedInstanceState, isReady)
|
super.onCreate(savedInstanceState, isReady)
|
||||||
setContentView(R.layout.activity_create_closed_group)
|
setContentView(R.layout.activity_create_closed_group)
|
||||||
supportActionBar!!.title = resources.getString(R.string.activity_create_closed_group_title)
|
supportActionBar!!.title = resources.getString(R.string.activity_create_closed_group_title)
|
||||||
recyclerView.adapter = createClosedGroupAdapter
|
|
||||||
|
this.selectContactsAdapter = SelectContactsAdapter(this, GlideApp.with(this))
|
||||||
|
recyclerView.adapter = this.selectContactsAdapter
|
||||||
recyclerView.layoutManager = LinearLayoutManager(this)
|
recyclerView.layoutManager = LinearLayoutManager(this)
|
||||||
createNewPrivateChatButton.setOnClickListener { createNewPrivateChat() }
|
|
||||||
|
btnCreateNewPrivateChat.setOnClickListener { createNewPrivateChat() }
|
||||||
LoaderManager.getInstance(this).initLoader(0, null, this)
|
LoaderManager.getInstance(this).initLoader(0, null, this)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -82,23 +81,17 @@ class CreateClosedGroupActivity : PassphraseRequiredActionBarActivity(), MemberC
|
|||||||
|
|
||||||
// region Interaction
|
// region Interaction
|
||||||
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
||||||
val id = item.itemId
|
when(item.itemId) {
|
||||||
when(id) {
|
|
||||||
R.id.doneButton -> createClosedGroup()
|
R.id.doneButton -> createClosedGroup()
|
||||||
else -> { /* Do nothing */ }
|
|
||||||
}
|
}
|
||||||
return super.onOptionsItemSelected(item)
|
return super.onOptionsItemSelected(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun createNewPrivateChat() {
|
private fun createNewPrivateChat() {
|
||||||
setResult(createNewPrivateChatResultCode)
|
setResult(RESULT_CODE_CREATE_CLOSED_GROUP)
|
||||||
finish()
|
finish()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onMemberClick(member: String) {
|
|
||||||
createClosedGroupAdapter.onMemberClick(member)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun createClosedGroup() {
|
private fun createClosedGroup() {
|
||||||
val name = nameEditText.text.trim()
|
val name = nameEditText.text.trim()
|
||||||
if (name.isEmpty()) {
|
if (name.isEmpty()) {
|
||||||
@ -107,7 +100,7 @@ class CreateClosedGroupActivity : PassphraseRequiredActionBarActivity(), MemberC
|
|||||||
if (name.length >= 64) {
|
if (name.length >= 64) {
|
||||||
return Toast.makeText(this, R.string.activity_create_closed_group_group_name_too_long_error, Toast.LENGTH_LONG).show()
|
return Toast.makeText(this, R.string.activity_create_closed_group_group_name_too_long_error, Toast.LENGTH_LONG).show()
|
||||||
}
|
}
|
||||||
val selectedMembers = this.selectedMembers
|
val selectedMembers = this.selectContactsAdapter.selectedMembers
|
||||||
if (selectedMembers.count() < 2) {
|
if (selectedMembers.count() < 2) {
|
||||||
return Toast.makeText(this, R.string.activity_create_closed_group_not_enough_group_members_error, Toast.LENGTH_LONG).show()
|
return Toast.makeText(this, R.string.activity_create_closed_group_not_enough_group_members_error, Toast.LENGTH_LONG).show()
|
||||||
}
|
}
|
||||||
@ -119,16 +112,8 @@ class CreateClosedGroupActivity : PassphraseRequiredActionBarActivity(), MemberC
|
|||||||
}.toSet()
|
}.toSet()
|
||||||
val masterHexEncodedPublicKey = TextSecurePreferences.getMasterHexEncodedPublicKey(this) ?: TextSecurePreferences.getLocalNumber(this)
|
val masterHexEncodedPublicKey = TextSecurePreferences.getMasterHexEncodedPublicKey(this) ?: TextSecurePreferences.getLocalNumber(this)
|
||||||
val admin = Recipient.from(this, Address.fromSerialized(masterHexEncodedPublicKey), false)
|
val admin = Recipient.from(this, Address.fromSerialized(masterHexEncodedPublicKey), false)
|
||||||
CreateClosedGroupTask(WeakReference(this), null, name.toString(), recipients, setOf( admin )).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR)
|
CreateClosedGroupTask(WeakReference(this), null, name.toString(), recipients, setOf( admin ))
|
||||||
}
|
.executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR)
|
||||||
|
|
||||||
private fun handleOpenConversation(threadId: Long, recipient: Recipient) {
|
|
||||||
val intent = Intent(this, ConversationActivity::class.java)
|
|
||||||
intent.putExtra(ConversationActivity.THREAD_ID_EXTRA, threadId)
|
|
||||||
intent.putExtra(ConversationActivity.DISTRIBUTION_TYPE_EXTRA, ThreadDatabase.DistributionTypes.DEFAULT)
|
|
||||||
intent.putExtra(ConversationActivity.ADDRESS_EXTRA, recipient.address)
|
|
||||||
startActivity(intent)
|
|
||||||
finish()
|
|
||||||
}
|
}
|
||||||
// endregion
|
// endregion
|
||||||
|
|
||||||
@ -150,7 +135,8 @@ class CreateClosedGroupActivity : PassphraseRequiredActionBarActivity(), MemberC
|
|||||||
val activity = activity.get() ?: return super.onPostExecute(result)
|
val activity = activity.get() ?: return super.onPostExecute(result)
|
||||||
if (result.isPresent && result.get().threadId > -1) {
|
if (result.isPresent && result.get().threadId > -1) {
|
||||||
if (!activity.isFinishing) {
|
if (!activity.isFinishing) {
|
||||||
activity.handleOpenConversation(result.get().threadId, result.get().groupRecipient)
|
openConversationActivity(activity, result.get().threadId, result.get().groupRecipient)
|
||||||
|
activity.finish()
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
super.onPostExecute(result)
|
super.onPostExecute(result)
|
||||||
@ -160,3 +146,11 @@ class CreateClosedGroupActivity : PassphraseRequiredActionBarActivity(), MemberC
|
|||||||
}
|
}
|
||||||
// endregion
|
// endregion
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun openConversationActivity(context: Context, threadId: Long, recipient: Recipient) {
|
||||||
|
val intent = Intent(context, ConversationActivity::class.java)
|
||||||
|
intent.putExtra(ConversationActivity.THREAD_ID_EXTRA, threadId)
|
||||||
|
intent.putExtra(ConversationActivity.DISTRIBUTION_TYPE_EXTRA, ThreadDatabase.DistributionTypes.DEFAULT)
|
||||||
|
intent.putExtra(ConversationActivity.ADDRESS_EXTRA, recipient.address)
|
||||||
|
context.startActivity(intent)
|
||||||
|
}
|
@ -80,7 +80,7 @@ class EditClosedGroupActivity : PassphraseRequiredActionBarActivity() {
|
|||||||
|
|
||||||
override fun onLoadFinished(loader: Loader<List<String>>, members: List<String>) {
|
override fun onLoadFinished(loader: Loader<List<String>>, members: List<String>) {
|
||||||
// We no longer need any subsequent loading events
|
// We no longer need any subsequent loading events
|
||||||
// (they will occur on every activity resume)
|
// (they will occur on every activity resume).
|
||||||
LoaderManager.getInstance(this@EditClosedGroupActivity).destroyLoader(LOADER_ID_MEMBERS)
|
LoaderManager.getInstance(this@EditClosedGroupActivity).destroyLoader(LOADER_ID_MEMBERS)
|
||||||
|
|
||||||
originalMembers.clear()
|
originalMembers.clear()
|
||||||
|
@ -31,7 +31,6 @@ import org.thoughtcrime.securesms.database.DatabaseFactory
|
|||||||
import org.thoughtcrime.securesms.database.ThreadDatabase
|
import org.thoughtcrime.securesms.database.ThreadDatabase
|
||||||
import org.thoughtcrime.securesms.database.model.ThreadRecord
|
import org.thoughtcrime.securesms.database.model.ThreadRecord
|
||||||
import org.thoughtcrime.securesms.jobs.MultiDeviceBlockedUpdateJob
|
import org.thoughtcrime.securesms.jobs.MultiDeviceBlockedUpdateJob
|
||||||
import org.thoughtcrime.securesms.loki.database.LokiAPIDatabase
|
|
||||||
import org.thoughtcrime.securesms.loki.dialogs.ConversationOptionsBottomSheet
|
import org.thoughtcrime.securesms.loki.dialogs.ConversationOptionsBottomSheet
|
||||||
import org.thoughtcrime.securesms.loki.dialogs.MultiDeviceRemovalBottomSheet
|
import org.thoughtcrime.securesms.loki.dialogs.MultiDeviceRemovalBottomSheet
|
||||||
import org.thoughtcrime.securesms.loki.protocol.ClosedGroupsProtocol
|
import org.thoughtcrime.securesms.loki.protocol.ClosedGroupsProtocol
|
||||||
@ -120,7 +119,7 @@ class HomeActivity : PassphraseRequiredActionBarActivity, ConversationClickListe
|
|||||||
recyclerView.adapter = homeAdapter
|
recyclerView.adapter = homeAdapter
|
||||||
recyclerView.layoutManager = LinearLayoutManager(this)
|
recyclerView.layoutManager = LinearLayoutManager(this)
|
||||||
// Set up empty state view
|
// Set up empty state view
|
||||||
createNewPrivateChatButton.setOnClickListener { createNewPrivateChat() }
|
btnCreateNewPrivateChat.setOnClickListener { createNewPrivateChat() }
|
||||||
// This is a workaround for the fact that CursorRecyclerViewAdapter doesn't actually auto-update (even though it says it will)
|
// This is a workaround for the fact that CursorRecyclerViewAdapter doesn't actually auto-update (even though it says it will)
|
||||||
LoaderManager.getInstance(this).restartLoader(0, null, object : LoaderManager.LoaderCallbacks<Cursor> {
|
LoaderManager.getInstance(this).restartLoader(0, null, object : LoaderManager.LoaderCallbacks<Cursor> {
|
||||||
|
|
||||||
@ -221,7 +220,7 @@ class HomeActivity : PassphraseRequiredActionBarActivity, ConversationClickListe
|
|||||||
|
|
||||||
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
|
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
|
||||||
super.onActivityResult(requestCode, resultCode, data)
|
super.onActivityResult(requestCode, resultCode, data)
|
||||||
if (resultCode == CreateClosedGroupActivity.createNewPrivateChatResultCode) {
|
if (resultCode == RESULT_CODE_CREATE_CLOSED_GROUP) {
|
||||||
createNewPrivateChat()
|
createNewPrivateChat()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package org.thoughtcrime.securesms.loki.activities
|
package org.thoughtcrime.securesms.loki.activities
|
||||||
|
|
||||||
|
@FunctionalInterface
|
||||||
interface MemberClickListener {
|
interface MemberClickListener {
|
||||||
fun onMemberClick(member: String)
|
fun onMemberClick(member: String)
|
||||||
}
|
}
|
@ -17,13 +17,13 @@ import org.thoughtcrime.securesms.mms.GlideApp
|
|||||||
|
|
||||||
const val EXTRA_SELECTED_CONTACTS = "SELECTED_CONTACTS_RESULT"
|
const val EXTRA_SELECTED_CONTACTS = "SELECTED_CONTACTS_RESULT"
|
||||||
|
|
||||||
class SelectContactsActivity : PassphraseRequiredActionBarActivity(), MemberClickListener, LoaderManager.LoaderCallbacks<List<String>> {
|
class SelectContactsActivity : PassphraseRequiredActionBarActivity(), LoaderManager.LoaderCallbacks<List<String>> {
|
||||||
private var members = listOf<String>()
|
private var members = listOf<String>()
|
||||||
set(value) { field = value; selectContactsAdapter.members = value }
|
set(value) { field = value; selectContactsAdapter.members = value }
|
||||||
|
|
||||||
private val selectContactsAdapter by lazy {
|
private val selectContactsAdapter by lazy {
|
||||||
val glide = GlideApp.with(this)
|
val glide = GlideApp.with(this)
|
||||||
val result = SelectContactsAdapter(this, glide, this)
|
val result = SelectContactsAdapter(this, glide)
|
||||||
result
|
result
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -41,7 +41,7 @@ class SelectContactsActivity : PassphraseRequiredActionBarActivity(), MemberClic
|
|||||||
supportActionBar!!.title = resources.getString(R.string.activity_select_contacts_title)
|
supportActionBar!!.title = resources.getString(R.string.activity_select_contacts_title)
|
||||||
recyclerView.adapter = selectContactsAdapter
|
recyclerView.adapter = selectContactsAdapter
|
||||||
recyclerView.layoutManager = LinearLayoutManager(this)
|
recyclerView.layoutManager = LinearLayoutManager(this)
|
||||||
createNewPrivateChatButton.setOnClickListener { createNewPrivateChat() }
|
btnCreateNewPrivateChat.setOnClickListener { createNewPrivateChat() }
|
||||||
LoaderManager.getInstance(this).initLoader(0, null, this)
|
LoaderManager.getInstance(this).initLoader(0, null, this)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -87,10 +87,6 @@ class SelectContactsActivity : PassphraseRequiredActionBarActivity(), MemberClic
|
|||||||
finish()
|
finish()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onMemberClick(member: String) {
|
|
||||||
selectContactsAdapter.onMemberClick(member)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun returnContacts() {
|
private fun returnContacts() {
|
||||||
val selectedMembers = this.selectedMembers
|
val selectedMembers = this.selectedMembers
|
||||||
val selectedContacts = selectedMembers.toTypedArray()
|
val selectedContacts = selectedMembers.toTypedArray()
|
||||||
|
@ -10,8 +10,7 @@ import org.thoughtcrime.securesms.recipients.Recipient
|
|||||||
|
|
||||||
class SelectContactsAdapter(
|
class SelectContactsAdapter(
|
||||||
private val context: Context,
|
private val context: Context,
|
||||||
private val glide: GlideRequests,
|
private val glide: GlideRequests)
|
||||||
private val memberClickListener: MemberClickListener? = null)
|
|
||||||
: RecyclerView.Adapter<SelectContactsAdapter.ViewHolder>() {
|
: RecyclerView.Adapter<SelectContactsAdapter.ViewHolder>() {
|
||||||
|
|
||||||
val selectedMembers = mutableSetOf<String>()
|
val selectedMembers = mutableSetOf<String>()
|
||||||
@ -32,12 +31,12 @@ class SelectContactsAdapter(
|
|||||||
|
|
||||||
override fun onBindViewHolder(viewHolder: ViewHolder, position: Int) {
|
override fun onBindViewHolder(viewHolder: ViewHolder, position: Int) {
|
||||||
val member = members[position]
|
val member = members[position]
|
||||||
viewHolder.view.setOnClickListener { memberClickListener?.onMemberClick(member) }
|
viewHolder.view.setOnClickListener { onMemberClick(member) }
|
||||||
val isSelected = selectedMembers.contains(member)
|
val isSelected = selectedMembers.contains(member)
|
||||||
viewHolder.view.bind(Recipient.from(context, Address.fromSerialized(member), false), isSelected, glide, false)
|
viewHolder.view.bind(Recipient.from(context, Address.fromSerialized(member), false), isSelected, glide, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun onMemberClick(member: String) {
|
private fun onMemberClick(member: String) {
|
||||||
if (selectedMembers.contains(member)) {
|
if (selectedMembers.contains(member)) {
|
||||||
selectedMembers.remove(member)
|
selectedMembers.remove(member)
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user