|
|
@ -360,6 +360,7 @@ public class FragmentMessages extends FragmentBase
|
|
|
|
private boolean quick_scroll;
|
|
|
|
private boolean quick_scroll;
|
|
|
|
private boolean addresses;
|
|
|
|
private boolean addresses;
|
|
|
|
private boolean swipe_reply;
|
|
|
|
private boolean swipe_reply;
|
|
|
|
|
|
|
|
private boolean quick_actions;
|
|
|
|
|
|
|
|
|
|
|
|
private int colorPrimary;
|
|
|
|
private int colorPrimary;
|
|
|
|
private int colorAccent;
|
|
|
|
private int colorAccent;
|
|
|
@ -503,6 +504,7 @@ public class FragmentMessages extends FragmentBase
|
|
|
|
quick_scroll = prefs.getBoolean("quick_scroll", true);
|
|
|
|
quick_scroll = prefs.getBoolean("quick_scroll", true);
|
|
|
|
addresses = prefs.getBoolean("addresses", false);
|
|
|
|
addresses = prefs.getBoolean("addresses", false);
|
|
|
|
swipe_reply = prefs.getBoolean("swipe_reply", false);
|
|
|
|
swipe_reply = prefs.getBoolean("swipe_reply", false);
|
|
|
|
|
|
|
|
quick_actions = prefs.getBoolean("quick_actions", true);
|
|
|
|
|
|
|
|
|
|
|
|
colorPrimary = Helper.resolveColor(getContext(), R.attr.colorPrimary);
|
|
|
|
colorPrimary = Helper.resolveColor(getContext(), R.attr.colorPrimary);
|
|
|
|
colorAccent = Helper.resolveColor(getContext(), R.attr.colorAccent);
|
|
|
|
colorAccent = Helper.resolveColor(getContext(), R.attr.colorAccent);
|
|
|
@ -6275,137 +6277,139 @@ public class FragmentMessages extends FragmentBase
|
|
|
|
tvSelectedCount.setCompoundDrawablesRelative(null, null, null, null);
|
|
|
|
tvSelectedCount.setCompoundDrawablesRelative(null, null, null, null);
|
|
|
|
tvSelectedCount.setVisibility(View.VISIBLE);
|
|
|
|
tvSelectedCount.setVisibility(View.VISIBLE);
|
|
|
|
|
|
|
|
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
if (quick_actions) {
|
|
|
|
args.putLongArray("ids", selection);
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
args.putBoolean("threading", threading);
|
|
|
|
args.putLongArray("ids", selection);
|
|
|
|
|
|
|
|
args.putBoolean("threading", threading);
|
|
|
|
|
|
|
|
|
|
|
|
new SimpleTask<MoreResult>() {
|
|
|
|
new SimpleTask<MoreResult>() {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
protected MoreResult onExecute(Context context, Bundle args) {
|
|
|
|
protected MoreResult onExecute(Context context, Bundle args) {
|
|
|
|
long[] ids = args.getLongArray("ids");
|
|
|
|
long[] ids = args.getLongArray("ids");
|
|
|
|
boolean threading = args.getBoolean("threading");
|
|
|
|
boolean threading = args.getBoolean("threading");
|
|
|
|
return MoreResult.get(context, ids, threading, true);
|
|
|
|
return MoreResult.get(context, ids, threading, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
protected void onExecuted(Bundle args, MoreResult result) {
|
|
|
|
protected void onExecuted(Bundle args, MoreResult result) {
|
|
|
|
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
|
|
|
|
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
|
|
|
|
boolean more_seen = prefs.getBoolean("more_seen", true);
|
|
|
|
boolean more_seen = prefs.getBoolean("more_seen", true);
|
|
|
|
boolean more_unseen = prefs.getBoolean("more_unseen", false);
|
|
|
|
boolean more_unseen = prefs.getBoolean("more_unseen", false);
|
|
|
|
boolean more_snooze = prefs.getBoolean("more_snooze", false);
|
|
|
|
boolean more_snooze = prefs.getBoolean("more_snooze", false);
|
|
|
|
boolean more_hide = prefs.getBoolean("more_hide", false);
|
|
|
|
boolean more_hide = prefs.getBoolean("more_hide", false);
|
|
|
|
boolean more_flag = prefs.getBoolean("more_flag", false);
|
|
|
|
boolean more_flag = prefs.getBoolean("more_flag", false);
|
|
|
|
boolean more_flag_color = prefs.getBoolean("more_flag_color", false);
|
|
|
|
boolean more_flag_color = prefs.getBoolean("more_flag_color", false);
|
|
|
|
boolean more_importance_high = prefs.getBoolean("more_importance_high", false);
|
|
|
|
boolean more_importance_high = prefs.getBoolean("more_importance_high", false);
|
|
|
|
boolean more_importance_normal = prefs.getBoolean("more_importance_normal", false);
|
|
|
|
boolean more_importance_normal = prefs.getBoolean("more_importance_normal", false);
|
|
|
|
boolean more_importance_low = prefs.getBoolean("more_importance_low", false);
|
|
|
|
boolean more_importance_low = prefs.getBoolean("more_importance_low", false);
|
|
|
|
boolean more_inbox = prefs.getBoolean("more_inbox", true);
|
|
|
|
boolean more_inbox = prefs.getBoolean("more_inbox", true);
|
|
|
|
boolean more_archive = prefs.getBoolean("more_archive", true);
|
|
|
|
boolean more_archive = prefs.getBoolean("more_archive", true);
|
|
|
|
boolean more_junk = prefs.getBoolean("more_junk", true);
|
|
|
|
boolean more_junk = prefs.getBoolean("more_junk", true);
|
|
|
|
boolean more_trash = prefs.getBoolean("more_trash", true);
|
|
|
|
boolean more_trash = prefs.getBoolean("more_trash", true);
|
|
|
|
boolean more_delete = prefs.getBoolean("more_delete", false);
|
|
|
|
boolean more_delete = prefs.getBoolean("more_delete", false);
|
|
|
|
boolean more_move = prefs.getBoolean("more_move", true);
|
|
|
|
boolean more_move = prefs.getBoolean("more_move", true);
|
|
|
|
|
|
|
|
|
|
|
|
boolean inTrash = EntityFolder.TRASH.equals(type);
|
|
|
|
boolean inTrash = EntityFolder.TRASH.equals(type);
|
|
|
|
boolean inJunk = EntityFolder.JUNK.equals(type);
|
|
|
|
boolean inJunk = EntityFolder.JUNK.equals(type);
|
|
|
|
|
|
|
|
|
|
|
|
int count = 0;
|
|
|
|
int count = 0;
|
|
|
|
|
|
|
|
|
|
|
|
boolean move = (more_move && count < MAX_QUICK_ACTIONS && result.canMove());
|
|
|
|
boolean move = (more_move && count < MAX_QUICK_ACTIONS && result.canMove());
|
|
|
|
if (move)
|
|
|
|
if (move)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean delete = (more_delete && count < MAX_QUICK_ACTIONS && result.canDelete());
|
|
|
|
boolean delete = (more_delete && count < MAX_QUICK_ACTIONS && result.canDelete());
|
|
|
|
if (delete)
|
|
|
|
if (delete)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean trash = (more_trash && count < MAX_QUICK_ACTIONS && result.canTrash());
|
|
|
|
boolean trash = (more_trash && count < MAX_QUICK_ACTIONS && result.canTrash());
|
|
|
|
if (trash)
|
|
|
|
if (trash)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
if (!delete && !trash && (inTrash || inJunk) &&
|
|
|
|
if (!delete && !trash && (inTrash || inJunk) &&
|
|
|
|
more_trash && count < MAX_QUICK_ACTIONS && result.canDelete()) {
|
|
|
|
more_trash && count < MAX_QUICK_ACTIONS && result.canDelete()) {
|
|
|
|
delete = true;
|
|
|
|
delete = true;
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
boolean junk = (more_junk && count < MAX_QUICK_ACTIONS && result.canJunk());
|
|
|
|
boolean junk = (more_junk && count < MAX_QUICK_ACTIONS && result.canJunk());
|
|
|
|
if (junk)
|
|
|
|
if (junk)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean archive = (more_archive && count < MAX_QUICK_ACTIONS && result.canArchive());
|
|
|
|
boolean archive = (more_archive && count < MAX_QUICK_ACTIONS && result.canArchive());
|
|
|
|
if (archive)
|
|
|
|
if (archive)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean inbox = ((more_inbox || (more_junk && inJunk)) && count < MAX_QUICK_ACTIONS && result.canInbox());
|
|
|
|
boolean inbox = ((more_inbox || (more_junk && inJunk)) && count < MAX_QUICK_ACTIONS && result.canInbox());
|
|
|
|
if (inbox)
|
|
|
|
if (inbox)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean importance_high = (more_importance_high && count < MAX_QUICK_ACTIONS &&
|
|
|
|
boolean importance_high = (more_importance_high && count < MAX_QUICK_ACTIONS &&
|
|
|
|
!EntityMessage.PRIORITIY_HIGH.equals(result.importance));
|
|
|
|
!EntityMessage.PRIORITIY_HIGH.equals(result.importance));
|
|
|
|
if (importance_high)
|
|
|
|
if (importance_high)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean importance_normal = (more_importance_normal && count < MAX_QUICK_ACTIONS &&
|
|
|
|
boolean importance_normal = (more_importance_normal && count < MAX_QUICK_ACTIONS &&
|
|
|
|
!EntityMessage.PRIORITIY_NORMAL.equals(result.importance));
|
|
|
|
!EntityMessage.PRIORITIY_NORMAL.equals(result.importance));
|
|
|
|
if (importance_normal)
|
|
|
|
if (importance_normal)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean importance_low = (more_importance_low && count < MAX_QUICK_ACTIONS &&
|
|
|
|
boolean importance_low = (more_importance_low && count < MAX_QUICK_ACTIONS &&
|
|
|
|
!EntityMessage.PRIORITIY_LOW.equals(result.importance));
|
|
|
|
!EntityMessage.PRIORITIY_LOW.equals(result.importance));
|
|
|
|
if (importance_low)
|
|
|
|
if (importance_low)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean flag = (more_flag && count < MAX_QUICK_ACTIONS && result.unflagged);
|
|
|
|
boolean flag = (more_flag && count < MAX_QUICK_ACTIONS && result.unflagged);
|
|
|
|
if (flag)
|
|
|
|
if (flag)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean flag_color = (more_flag_color && count < MAX_QUICK_ACTIONS && (result.unflagged || result.flagged));
|
|
|
|
boolean flag_color = (more_flag_color && count < MAX_QUICK_ACTIONS && (result.unflagged || result.flagged));
|
|
|
|
if (flag_color)
|
|
|
|
if (flag_color)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean hide = (more_hide && count < MAX_QUICK_ACTIONS && result.visible);
|
|
|
|
boolean hide = (more_hide && count < MAX_QUICK_ACTIONS && result.visible);
|
|
|
|
if (hide)
|
|
|
|
if (hide)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean snooze = (more_snooze && count < MAX_QUICK_ACTIONS);
|
|
|
|
boolean snooze = (more_snooze && count < MAX_QUICK_ACTIONS);
|
|
|
|
if (snooze)
|
|
|
|
if (snooze)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean unseen = (more_unseen && count < MAX_QUICK_ACTIONS && result.seen);
|
|
|
|
boolean unseen = (more_unseen && count < MAX_QUICK_ACTIONS && result.seen);
|
|
|
|
if (unseen)
|
|
|
|
if (unseen)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
boolean seen = (more_seen && count < MAX_QUICK_ACTIONS && result.unseen);
|
|
|
|
boolean seen = (more_seen && count < MAX_QUICK_ACTIONS && result.unseen);
|
|
|
|
if (seen)
|
|
|
|
if (seen)
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
|
|
|
|
ibInbox.setImageResource(inJunk ? R.drawable.twotone_report_off_24 : R.drawable.twotone_inbox_24);
|
|
|
|
ibInbox.setImageResource(inJunk ? R.drawable.twotone_report_off_24 : R.drawable.twotone_inbox_24);
|
|
|
|
|
|
|
|
|
|
|
|
ibBatchSeen.setVisibility(seen ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchSeen.setVisibility(seen ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchUnseen.setVisibility(unseen ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchUnseen.setVisibility(unseen ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchSnooze.setVisibility(snooze ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchSnooze.setVisibility(snooze ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchHide.setVisibility(hide ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchHide.setVisibility(hide ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchFlag.setVisibility(flag ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchFlag.setVisibility(flag ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchFlagColor.setVisibility(flag_color ? View.VISIBLE : View.GONE);
|
|
|
|
ibBatchFlagColor.setVisibility(flag_color ? View.VISIBLE : View.GONE);
|
|
|
|
ibLowImportance.setVisibility(importance_low ? View.VISIBLE : View.GONE);
|
|
|
|
ibLowImportance.setVisibility(importance_low ? View.VISIBLE : View.GONE);
|
|
|
|
ibNormalImportance.setVisibility(importance_normal ? View.VISIBLE : View.GONE);
|
|
|
|
ibNormalImportance.setVisibility(importance_normal ? View.VISIBLE : View.GONE);
|
|
|
|
ibHighImportance.setVisibility(importance_high ? View.VISIBLE : View.GONE);
|
|
|
|
ibHighImportance.setVisibility(importance_high ? View.VISIBLE : View.GONE);
|
|
|
|
ibInbox.setVisibility(inbox ? View.VISIBLE : View.GONE);
|
|
|
|
ibInbox.setVisibility(inbox ? View.VISIBLE : View.GONE);
|
|
|
|
ibArchive.setVisibility(archive ? View.VISIBLE : View.GONE);
|
|
|
|
ibArchive.setVisibility(archive ? View.VISIBLE : View.GONE);
|
|
|
|
ibJunk.setVisibility(junk ? View.VISIBLE : View.GONE);
|
|
|
|
ibJunk.setVisibility(junk ? View.VISIBLE : View.GONE);
|
|
|
|
ibTrash.setVisibility(trash ? View.VISIBLE : View.GONE);
|
|
|
|
ibTrash.setVisibility(trash ? View.VISIBLE : View.GONE);
|
|
|
|
ibDelete.setVisibility(delete ? View.VISIBLE : View.GONE);
|
|
|
|
ibDelete.setVisibility(delete ? View.VISIBLE : View.GONE);
|
|
|
|
ibMove.setVisibility(move ? View.VISIBLE : View.GONE);
|
|
|
|
ibMove.setVisibility(move ? View.VISIBLE : View.GONE);
|
|
|
|
cardMore.setTag(fabMore.isOrWillBeShown() ? result : null);
|
|
|
|
cardMore.setTag(fabMore.isOrWillBeShown() ? result : null);
|
|
|
|
cardMore.setVisibility(fabMore.isOrWillBeShown() ? View.VISIBLE : View.GONE);
|
|
|
|
cardMore.setVisibility(fabMore.isOrWillBeShown() ? View.VISIBLE : View.GONE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
protected void onException(Bundle args, Throwable ex) {
|
|
|
|
protected void onException(Bundle args, Throwable ex) {
|
|
|
|
Log.unexpectedError(getParentFragmentManager(), ex);
|
|
|
|
Log.unexpectedError(getParentFragmentManager(), ex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}.serial().setId("messages:" + FragmentMessages.this.hashCode()).execute(this, args, "quickactions");
|
|
|
|
}.serial().setId("messages:" + FragmentMessages.this.hashCode()).execute(this, args, "quickactions");
|
|
|
|
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
fabMore.hide();
|
|
|
|
fabMore.hide();
|
|
|
|
tvSelectedCount.setVisibility(View.GONE);
|
|
|
|
tvSelectedCount.setVisibility(View.GONE);
|
|
|
|