|
|
@ -2156,26 +2156,68 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
|
|
|
|
protected MoreResult onExecute(Context context, Bundle args) {
|
|
|
|
protected MoreResult onExecute(Context context, Bundle args) {
|
|
|
|
long[] ids = args.getLongArray("ids");
|
|
|
|
long[] ids = args.getLongArray("ids");
|
|
|
|
|
|
|
|
|
|
|
|
MoreResult result = new MoreResult();
|
|
|
|
Map<Long, EntityAccount> accounts = new HashMap<>();
|
|
|
|
|
|
|
|
Map<Long, EntityFolder> folders = new HashMap<>();
|
|
|
|
|
|
|
|
|
|
|
|
DB db = DB.getInstance(context);
|
|
|
|
DB db = DB.getInstance(context);
|
|
|
|
|
|
|
|
|
|
|
|
boolean pop = false;
|
|
|
|
boolean pop = false;
|
|
|
|
|
|
|
|
MoreResult result = new MoreResult();
|
|
|
|
result.folders = new ArrayList<>();
|
|
|
|
result.folders = new ArrayList<>();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (ids.length > 100) {
|
|
|
|
|
|
|
|
result.seen = true;
|
|
|
|
|
|
|
|
result.unseen = true;
|
|
|
|
|
|
|
|
result.flagged = true;
|
|
|
|
|
|
|
|
result.unflagged = true;
|
|
|
|
|
|
|
|
result.importance = -1;
|
|
|
|
|
|
|
|
result.visible = true;
|
|
|
|
|
|
|
|
result.hidden = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (long id : ids) {
|
|
|
|
for (long id : ids) {
|
|
|
|
EntityMessage message = db.message().getMessage(id);
|
|
|
|
EntityMessage message = db.message().getMessage(id);
|
|
|
|
if (message == null)
|
|
|
|
if (message == null)
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
EntityAccount account = db.account().getAccount(message.account);
|
|
|
|
EntityAccount account = accounts.get(message.account);
|
|
|
|
if (account == null)
|
|
|
|
if (account == null) {
|
|
|
|
continue;
|
|
|
|
account = db.account().getAccount(message.account);
|
|
|
|
|
|
|
|
if (account == null)
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
accounts.put(account.id, account);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
EntityFolder folder = folders.get(message.folder);
|
|
|
|
|
|
|
|
if (folder == null) {
|
|
|
|
|
|
|
|
folder = db.folder().getFolder(message.folder);
|
|
|
|
|
|
|
|
if (folder == null)
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
folders.put(folder.id, folder);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (account.protocol != EntityAccount.TYPE_IMAP)
|
|
|
|
if (account.protocol != EntityAccount.TYPE_IMAP)
|
|
|
|
pop = true;
|
|
|
|
pop = true;
|
|
|
|
|
|
|
|
|
|
|
|
if (!result.folders.contains(message.folder))
|
|
|
|
if (!result.folders.contains(message.folder))
|
|
|
|
result.folders.add(message.folder);
|
|
|
|
result.folders.add(message.folder);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
boolean isArchive = EntityFolder.ARCHIVE.equals(folder.type);
|
|
|
|
|
|
|
|
boolean isTrash = (EntityFolder.TRASH.equals(folder.type) || account.protocol != EntityAccount.TYPE_IMAP);
|
|
|
|
|
|
|
|
boolean isJunk = EntityFolder.JUNK.equals(folder.type);
|
|
|
|
|
|
|
|
boolean isDrafts = EntityFolder.DRAFTS.equals(folder.type);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result.isArchive = (result.isArchive == null ? isArchive : result.isArchive && isArchive);
|
|
|
|
|
|
|
|
result.isTrash = (result.isTrash == null ? isTrash : result.isTrash && isTrash);
|
|
|
|
|
|
|
|
result.isJunk = (result.isJunk == null ? isJunk : result.isJunk && isJunk);
|
|
|
|
|
|
|
|
result.isDrafts = (result.isDrafts == null ? isDrafts : result.isDrafts && isDrafts);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (result.seen && result.unseen &&
|
|
|
|
|
|
|
|
result.flagged && result.unflagged &&
|
|
|
|
|
|
|
|
result.importance == -1 &&
|
|
|
|
|
|
|
|
result.visible && result.hidden)
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
List<EntityMessage> messages = db.message().getMessagesByThread(
|
|
|
|
List<EntityMessage> messages = db.message().getMessagesByThread(
|
|
|
|
message.account, message.thread, threading ? null : id, null);
|
|
|
|
message.account, message.thread, threading ? null : id, null);
|
|
|
|
for (EntityMessage threaded : messages) {
|
|
|
|
for (EntityMessage threaded : messages) {
|
|
|
@ -2202,21 +2244,12 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
|
|
|
|
else
|
|
|
|
else
|
|
|
|
result.hidden = true;
|
|
|
|
result.hidden = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
EntityFolder folder = db.folder().getFolder(message.folder);
|
|
|
|
for (EntityAccount account : accounts.values()) {
|
|
|
|
boolean isArchive = EntityFolder.ARCHIVE.equals(folder.type);
|
|
|
|
boolean hasArchive = (db.folder().getFolderByType(account.id, EntityFolder.ARCHIVE) != null);
|
|
|
|
boolean isTrash = (EntityFolder.TRASH.equals(folder.type) || account.protocol != EntityAccount.TYPE_IMAP);
|
|
|
|
boolean hasTrash = (db.folder().getFolderByType(account.id, EntityFolder.TRASH) != null);
|
|
|
|
boolean isJunk = EntityFolder.JUNK.equals(folder.type);
|
|
|
|
boolean hasJunk = (db.folder().getFolderByType(account.id, EntityFolder.JUNK) != null);
|
|
|
|
boolean isDrafts = EntityFolder.DRAFTS.equals(folder.type);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result.isArchive = (result.isArchive == null ? isArchive : result.isArchive && isArchive);
|
|
|
|
|
|
|
|
result.isTrash = (result.isTrash == null ? isTrash : result.isTrash && isTrash);
|
|
|
|
|
|
|
|
result.isJunk = (result.isJunk == null ? isJunk : result.isJunk && isJunk);
|
|
|
|
|
|
|
|
result.isDrafts = (result.isDrafts == null ? isDrafts : result.isDrafts && isDrafts);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
boolean hasArchive = (db.folder().getFolderByType(message.account, EntityFolder.ARCHIVE) != null);
|
|
|
|
|
|
|
|
boolean hasTrash = (db.folder().getFolderByType(message.account, EntityFolder.TRASH) != null);
|
|
|
|
|
|
|
|
boolean hasJunk = (db.folder().getFolderByType(message.account, EntityFolder.JUNK) != null);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result.hasArchive = (result.hasArchive == null ? hasArchive : result.hasArchive && hasArchive);
|
|
|
|
result.hasArchive = (result.hasArchive == null ? hasArchive : result.hasArchive && hasArchive);
|
|
|
|
result.hasTrash = (result.hasTrash == null ? hasTrash : result.hasTrash && hasTrash);
|
|
|
|
result.hasTrash = (result.hasTrash == null ? hasTrash : result.hasTrash && hasTrash);
|
|
|
|