Set the search mailbox's syncState as soon as a search is requested
b/15868294 b/17377040 When we do a search, we clear the current contents of the search mailbox, and then send a request to whatever service is appropriate (IMAP or Exchange.) The service then begins a sync and updates the sync state. The thing is, this leaves a time window when the sync state is still NONE, but no contents have been loaded yet. So now, as soon as the search request is made, we set the sync state to LIVE, then send off the request. That should keep the empty state view hidden until we actually do the sync. Change-Id: Ia97e1cf2773db460fdf32aaa45205c4e6034527d
This commit is contained in:
parent
1927361b25
commit
00fbbb24b3
@ -5882,16 +5882,26 @@ public class EmailProvider extends ContentProvider
|
|||||||
// TODO: This conditional is unnecessary, just two lines earlier we created
|
// TODO: This conditional is unnecessary, just two lines earlier we created
|
||||||
// mSearchParams using a constructor that never sets mOffset.
|
// mSearchParams using a constructor that never sets mOffset.
|
||||||
LogUtils.d(TAG, "deleting existing search results.");
|
LogUtils.d(TAG, "deleting existing search results.");
|
||||||
|
final ContentResolver resolver = context.getContentResolver();
|
||||||
// Delete existing contents of search mailbox
|
final ContentValues cv = new ContentValues(3);
|
||||||
ContentResolver resolver = context.getContentResolver();
|
|
||||||
resolver.delete(Message.CONTENT_URI, MessageColumns.MAILBOX_KEY + "=" + searchMailboxId,
|
|
||||||
null);
|
|
||||||
final ContentValues cv = new ContentValues(1);
|
|
||||||
// For now, use the actual query as the name of the mailbox
|
// For now, use the actual query as the name of the mailbox
|
||||||
cv.put(Mailbox.DISPLAY_NAME, mSearchParams.mFilter);
|
cv.put(Mailbox.DISPLAY_NAME, mSearchParams.mFilter);
|
||||||
|
// We are about to do a sync on this folder, but if the UI is refreshed before the
|
||||||
|
// service can start its query, we need it to see that there is a sync in progress.
|
||||||
|
// Otherwise it could show the empty state, until the service gets around to setting
|
||||||
|
// the syncState.
|
||||||
|
cv.put(Mailbox.SYNC_STATUS, EmailContent.SYNC_STATUS_LIVE);
|
||||||
|
// We don't know how many result we'll have yet, but we assume zero until we get
|
||||||
|
// a response back from the server. Otherwise, we'll whatever count there was on the
|
||||||
|
// previous search, and we'll display the "Load More" footer prior to having
|
||||||
|
// any results.
|
||||||
|
cv.put(Mailbox.TOTAL_COUNT, 0);
|
||||||
resolver.update(ContentUris.withAppendedId(Mailbox.CONTENT_URI, searchMailboxId),
|
resolver.update(ContentUris.withAppendedId(Mailbox.CONTENT_URI, searchMailboxId),
|
||||||
cv, null, null);
|
cv, null, null);
|
||||||
|
|
||||||
|
// Delete existing contents of search mailbox
|
||||||
|
resolver.delete(Message.CONTENT_URI, MessageColumns.MAILBOX_KEY + "=" + searchMailboxId,
|
||||||
|
null);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Start the search running in the background
|
// Start the search running in the background
|
||||||
|
Loading…
Reference in New Issue
Block a user