refresh conversation fragment to new thread when created

This commit is contained in:
Jake McGinty 2014-02-17 15:47:58 -08:00
parent e81526e581
commit 04327e9ed7

View File

@ -93,7 +93,6 @@ import org.whispersystems.textsecure.storage.Session;
import org.whispersystems.textsecure.util.Util; import org.whispersystems.textsecure.util.Util;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
@ -171,7 +170,6 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
@Override @Override
protected void onResume() { protected void onResume() {
if (recipients == null || recipients.isEmpty())
initializeRecipientsInput(); initializeRecipientsInput();
super.onResume(); super.onResume();
@ -207,18 +205,24 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
Log.w("ComposeMessageActivity", "onActivityResult called: " + resultCode + " , " + data); Log.w("ComposeMessageActivity", "onActivityResult called: " + resultCode + " , " + data);
super.onActivityResult(reqCode, resultCode, data); super.onActivityResult(reqCode, resultCode, data);
if (data == null || resultCode != RESULT_OK) return;
switch (reqCode) { switch (reqCode) {
case PICK_CONTACT:
Recipients recipients = data.getParcelableExtra("recipients");
if (recipients != null)
recipientsPanel.addRecipients(recipients);
break;
case PICK_IMAGE: case PICK_IMAGE:
if (data != null && resultCode == RESULT_OK) addAttachmentImage(data.getData()); addAttachmentImage(data.getData());
break; break;
case PICK_VIDEO: case PICK_VIDEO:
if (data != null && resultCode == RESULT_OK) addAttachmentVideo(data.getData()); addAttachmentVideo(data.getData());
break; break;
case PICK_AUDIO: case PICK_AUDIO:
if (data != null && resultCode == RESULT_OK) addAttachmentAudio(data.getData()); addAttachmentAudio(data.getData());
break; break;
case PICK_CONTACT_INFO: case PICK_CONTACT_INFO:
if (data != null && resultCode == RESULT_OK) addContactInfo(data.getData()); addContactInfo(data.getData());
break; break;
} }
} }
@ -580,11 +584,11 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
} }
private void initializeResources() { private void initializeResources() {
recipientsPanel = (RecipientsPanel)findViewById(R.id.recipients);
recipients = getIntent().getParcelableExtra(RECIPIENTS_EXTRA); recipients = getIntent().getParcelableExtra(RECIPIENTS_EXTRA);
threadId = getIntent().getLongExtra(THREAD_ID_EXTRA, -1); threadId = getIntent().getLongExtra(THREAD_ID_EXTRA, -1);
distributionType = getIntent().getIntExtra(DISTRIBUTION_TYPE_EXTRA, distributionType = getIntent().getIntExtra(DISTRIBUTION_TYPE_EXTRA,
ThreadDatabase.DistributionTypes.DEFAULT); ThreadDatabase.DistributionTypes.DEFAULT);
recipientsPanel = (RecipientsPanel)findViewById(R.id.recipients);
addContactButton = (ImageButton)findViewById(R.id.contacts_button); addContactButton = (ImageButton)findViewById(R.id.contacts_button);
sendButton = (ImageButton)findViewById(R.id.send_button); sendButton = (ImageButton)findViewById(R.id.send_button);
composeText = (EditText)findViewById(R.id.embedded_text_editor); composeText = (EditText)findViewById(R.id.embedded_text_editor);
@ -627,8 +631,14 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
} }
private void initializeRecipientsInput() { private void initializeRecipientsInput() {
Intent intent = new Intent(ConversationActivity.this, SingleContactSelectionActivity.class); if (recipients == null || recipients.isEmpty())
startActivityForResult(intent, PICK_CONTACT); recipientsPanel.setVisibility(View.VISIBLE);
else if (recipients != null) {
recipientsPanel.addRecipients(this.recipients);
} else {
InputMethodManager input = (InputMethodManager)getSystemService(Context.INPUT_METHOD_SERVICE);
input.toggleSoftInput(InputMethodManager.SHOW_IMPLICIT, 0);
}
} }
private void initializeReceivers() { private void initializeReceivers() {
@ -846,7 +856,7 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
}.execute(threadId); }.execute(threadId);
} }
private void sendComplete(Recipients recipients, long threadId) { private void sendComplete(Recipients recipients, long threadId, boolean refreshFragment) {
attachmentManager.clear(); attachmentManager.clear();
recipientsPanel.disable(); recipientsPanel.disable();
composeText.setText(""); composeText.setText("");
@ -854,7 +864,7 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
this.recipients = recipients; this.recipients = recipients;
this.threadId = threadId; this.threadId = threadId;
if (this.recipientsPanel.getVisibility() == View.VISIBLE) { if (refreshFragment) {
ConversationFragment fragment ConversationFragment fragment
= (ConversationFragment)this.getSupportFragmentManager() = (ConversationFragment)this.getSupportFragmentManager()
.findFragmentById(R.id.fragment_content); .findFragmentById(R.id.fragment_content);
@ -901,7 +911,7 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
allocatedThreadId = MessageSender.send(ConversationActivity.this, masterSecret, allocatedThreadId = MessageSender.send(ConversationActivity.this, masterSecret,
message, threadId); message, threadId);
} }
sendComplete(recipients, allocatedThreadId); sendComplete(recipients, allocatedThreadId, allocatedThreadId != this.threadId);
} catch (RecipientFormattingException ex) { } catch (RecipientFormattingException ex) {
Toast.makeText(ConversationActivity.this, Toast.makeText(ConversationActivity.this,
R.string.ConversationActivity_recipient_is_not_a_valid_sms_or_email_address_exclamation, R.string.ConversationActivity_recipient_is_not_a_valid_sms_or_email_address_exclamation,