Merge change 23803 into eclair
* changes: MessageCompose: Bug 2078435, Correctly set the attachement flag.
This commit is contained in:
commit
5d09beeacb
@ -143,6 +143,7 @@ public class MessageCompose extends Activity implements OnClickListener, OnFocus
|
|||||||
private Listener mListener = new Listener();
|
private Listener mListener = new Listener();
|
||||||
private boolean mDraftNeedsSaving;
|
private boolean mDraftNeedsSaving;
|
||||||
private AsyncTask mLoadAttachmentsTask;
|
private AsyncTask mLoadAttachmentsTask;
|
||||||
|
private AsyncTask mSaveMessageTask;
|
||||||
|
|
||||||
private Handler mHandler = new Handler() {
|
private Handler mHandler = new Handler() {
|
||||||
@Override
|
@Override
|
||||||
@ -320,6 +321,12 @@ public class MessageCompose extends Activity implements OnClickListener, OnFocus
|
|||||||
mController.removeResultCallback(mListener);
|
mController.removeResultCallback(mListener);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void cancelTask(AsyncTask<?, ?, ?> task) {
|
||||||
|
if (task != null && task.getStatus() != AsyncTask.Status.FINISHED) {
|
||||||
|
task.cancel(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* We override onDestroy to make sure that the WebView gets explicitly destroyed.
|
* We override onDestroy to make sure that the WebView gets explicitly destroyed.
|
||||||
* Otherwise it can leak native references.
|
* Otherwise it can leak native references.
|
||||||
@ -329,11 +336,10 @@ public class MessageCompose extends Activity implements OnClickListener, OnFocus
|
|||||||
super.onDestroy();
|
super.onDestroy();
|
||||||
mQuotedText.destroy();
|
mQuotedText.destroy();
|
||||||
mQuotedText = null;
|
mQuotedText = null;
|
||||||
if (mLoadAttachmentsTask != null
|
cancelTask(mLoadAttachmentsTask);
|
||||||
&& mLoadAttachmentsTask.getStatus() != AsyncTask.Status.FINISHED) {
|
mLoadAttachmentsTask = null;
|
||||||
mLoadAttachmentsTask.cancel(true);
|
// don't cancel mSaveMessageTask, let it do its job to the end.
|
||||||
mLoadAttachmentsTask = null;
|
// cancelTask(mSaveMessageTask);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -617,7 +623,7 @@ public class MessageCompose extends Activity implements OnClickListener, OnFocus
|
|||||||
values.put(MessageColumns.SUBJECT, message.mSubject);
|
values.put(MessageColumns.SUBJECT, message.mSubject);
|
||||||
values.put(MessageColumns.DISPLAY_NAME, message.mDisplayName);
|
values.put(MessageColumns.DISPLAY_NAME, message.mDisplayName);
|
||||||
values.put(MessageColumns.FLAG_LOADED, message.mFlagLoaded);
|
values.put(MessageColumns.FLAG_LOADED, message.mFlagLoaded);
|
||||||
// TODO: write body and update TEXT_INFO
|
values.put(MessageColumns.FLAG_ATTACHMENT, message.mFlagAttachment);
|
||||||
return values;
|
return values;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -651,7 +657,8 @@ public class MessageCompose extends Activity implements OnClickListener, OnFocus
|
|||||||
* @param account the account (used to obtain From: address).
|
* @param account the account (used to obtain From: address).
|
||||||
* @param bodyText the body text.
|
* @param bodyText the body text.
|
||||||
*/
|
*/
|
||||||
private void updateMessage(Message message, Account account, String bodyText) {
|
private void updateMessage(Message message, Account account, String bodyText,
|
||||||
|
boolean hasAttachments) {
|
||||||
message.mTimeStamp = System.currentTimeMillis();
|
message.mTimeStamp = System.currentTimeMillis();
|
||||||
message.mFrom = new Address(account.getEmailAddress(), account.getSenderName()).pack();
|
message.mFrom = new Address(account.getEmailAddress(), account.getSenderName()).pack();
|
||||||
message.mTo = getPackedAddresses(mToView);
|
message.mTo = getPackedAddresses(mToView);
|
||||||
@ -662,6 +669,7 @@ public class MessageCompose extends Activity implements OnClickListener, OnFocus
|
|||||||
message.mAccountKey = account.mId;
|
message.mAccountKey = account.mId;
|
||||||
message.mDisplayName = makeDisplayName(message.mTo, message.mCc, message.mBcc);
|
message.mDisplayName = makeDisplayName(message.mTo, message.mCc, message.mBcc);
|
||||||
message.mFlagLoaded = Message.LOADED;
|
message.mFlagLoaded = Message.LOADED;
|
||||||
|
message.mFlagAttachment = hasAttachments;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Attachment[] getAttachmentsFromUI() {
|
private Attachment[] getAttachmentsFromUI() {
|
||||||
@ -684,50 +692,46 @@ public class MessageCompose extends Activity implements OnClickListener, OnFocus
|
|||||||
if (mDraft == null) {
|
if (mDraft == null) {
|
||||||
mDraft = new Message();
|
mDraft = new Message();
|
||||||
}
|
}
|
||||||
updateMessage(mDraft, mAccount, buildBodyText(mSource));
|
final Attachment[] attachments = getAttachmentsFromUI();
|
||||||
|
updateMessage(mDraft, mAccount, buildBodyText(mSource), attachments.length > 0);
|
||||||
|
|
||||||
new AsyncTask<Void, Void, Void>() {
|
mSaveMessageTask = new AsyncTask<Void, Void, Void>() {
|
||||||
@Override
|
@Override
|
||||||
protected Void doInBackground(Void... params) {
|
protected Void doInBackground(Void... params) {
|
||||||
final String action = getIntent().getAction();
|
synchronized (mDraft) {
|
||||||
if (mDraft.isSaved()) {
|
if (mDraft.isSaved()) {
|
||||||
mDraft.update(MessageCompose.this, getUpdateContentValues(mDraft));
|
mDraft.update(MessageCompose.this, getUpdateContentValues(mDraft));
|
||||||
ContentValues values = new ContentValues();
|
ContentValues values = new ContentValues();
|
||||||
values.put(BodyColumns.TEXT_CONTENT, mDraft.mText);
|
values.put(BodyColumns.TEXT_CONTENT, mDraft.mText);
|
||||||
Body.updateBodyWithMessageId(MessageCompose.this, mDraft.mId, values);
|
Body.updateBodyWithMessageId(MessageCompose.this, mDraft.mId, values);
|
||||||
} else {
|
} else {
|
||||||
// mDraft.mId is set upon return of saveToMailbox()
|
// mDraft.mId is set upon return of saveToMailbox()
|
||||||
mController.saveToMailbox(mDraft, EmailContent.Mailbox.TYPE_DRAFTS);
|
mController.saveToMailbox(mDraft, EmailContent.Mailbox.TYPE_DRAFTS);
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: remove from DB the attachments that were removed from UI
|
|
||||||
for (Attachment attachment : getAttachmentsFromUI()) {
|
|
||||||
if (!attachment.isSaved()) {
|
|
||||||
// this attachment is new so save it to DB.
|
|
||||||
attachment.mMessageKey = mDraft.mId;
|
|
||||||
attachment.save(MessageCompose.this);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (send) {
|
// TODO: remove from DB the attachments that were removed from UI
|
||||||
mController.sendMessage(mDraft.mId, mDraft.mAccountKey);
|
for (Attachment attachment : attachments) {
|
||||||
// After a send it's no longer a draft; null it here just to be sure,
|
if (!attachment.isSaved()) {
|
||||||
// although MessageCompose should just finish() anyway.
|
// this attachment is new so save it to DB.
|
||||||
mDraft = null;
|
attachment.mMessageKey = mDraft.mId;
|
||||||
|
attachment.save(MessageCompose.this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (send) {
|
||||||
|
mController.sendMessage(mDraft.mId, mDraft.mAccountKey);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onPostExecute(Void dummy) {
|
protected void onPostExecute(Void dummy) {
|
||||||
// TODO: fix toast display for "saved as draft" if needed
|
// Don't display the toast if the user is just changing the orientation
|
||||||
// if (!send) {
|
if (!send && (getChangingConfigurations() & ActivityInfo.CONFIG_ORIENTATION) == 0) {
|
||||||
// // Don't display the toast if the user is just changing the orientation
|
Toast.makeText(MessageCompose.this, R.string.message_saved_toast,
|
||||||
// if ((getChangingConfigurations() & ActivityInfo.CONFIG_ORIENTATION) == 0) {
|
Toast.LENGTH_LONG).show();
|
||||||
// Toast.makeText(MessageCompose.this, getString(R.string.message_saved_toast),
|
}
|
||||||
// Toast.LENGTH_LONG).show();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
}.execute();
|
}.execute();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user