Fast auto close

pull/180/head
M66B 5 years ago
parent b47bbd72d8
commit 4d06d29457

@ -3992,7 +3992,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
return; return;
if (viewType == AdapterMessage.ViewType.THREAD) { if (viewType == AdapterMessage.ViewType.THREAD) {
if (handleThreadActions(messages)) if (handleThreadActions(messages, null))
return; return;
} else { } else {
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getContext()); SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getContext());
@ -4055,7 +4055,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
" no=" + (tvNoEmail.getVisibility() == View.VISIBLE)); " no=" + (tvNoEmail.getVisibility() == View.VISIBLE));
} }
private boolean handleThreadActions(@NonNull PagedList<TupleMessageEx> messages) { private boolean handleThreadActions(@NonNull PagedList<TupleMessageEx> messages, ArrayList<MessageTarget> targets) {
// Auto close / next // Auto close / next
if (messages.size() == 0 && (autoclose || onclose != null)) { if (messages.size() == 0 && (autoclose || onclose != null)) {
handleAutoClose(); handleAutoClose();
@ -4159,11 +4159,21 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
TupleMessageEx message = messages.get(i); TupleMessageEx message = messages.get(i);
if (message == null) if (message == null)
continue; continue;
if (!(EntityFolder.OUTBOX.equals(message.folderType) && message.ui_snoozed != null) &&
!(EntityFolder.ARCHIVE.equals(message.folderType) && filter_archive) && String folderType = message.folderType;
!EntityFolder.SENT.equals(message.folderType) && if (targets != null)
!EntityFolder.TRASH.equals(message.folderType) && for (MessageTarget target : targets)
!EntityFolder.JUNK.equals(message.folderType)) if (!target.across && message.id.equals(target.id)) {
folderType = target.folder.type;
Log.i("Eval thread target=" + folderType);
break;
}
if (!(EntityFolder.OUTBOX.equals(folderType) && message.ui_snoozed != null) &&
!(EntityFolder.ARCHIVE.equals(folderType) && filter_archive) &&
!EntityFolder.SENT.equals(folderType) &&
!EntityFolder.TRASH.equals(folderType) &&
!EntityFolder.JUNK.equals(folderType))
count++; count++;
} }
Log.i("Auto close=" + count); Log.i("Auto close=" + count);
@ -4494,6 +4504,17 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
return null; return null;
} }
@Override
protected void onExecuted(Bundle args, Void data) {
if (viewType == AdapterMessage.ViewType.THREAD) {
PagedList<TupleMessageEx> messages = adapter.getCurrentList();
if (messages != null && result.size() > 0) {
Log.i("Eval thread messages=" + messages.size() + " targets=" + result.size());
handleThreadActions(messages, result);
}
}
}
@Override @Override
protected void onException(Bundle args, Throwable ex) { protected void onException(Bundle args, Throwable ex) {
if (ex instanceof IllegalArgumentException) if (ex instanceof IllegalArgumentException)

Loading…
Cancel
Save