mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-03 05:34:51 +00:00
Swipe/ask: added trash/archive
This commit is contained in:
parent
c1909db169
commit
cddcaf6819
1 changed files with 188 additions and 149 deletions
|
@ -3420,158 +3420,197 @@ public class FragmentMessages extends FragmentBase
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onSwipeAsk(final @NonNull TupleMessageEx message, @NonNull View anchor) {
|
private void onSwipeAsk(final @NonNull TupleMessageEx message, @NonNull View anchor) {
|
||||||
// Make sure animations are done
|
Bundle args = new Bundle();
|
||||||
rvMessage.post(new Runnable() {
|
args.putLong("account", message.account);
|
||||||
|
|
||||||
|
new SimpleTask<Pair<EntityFolder, EntityFolder>>() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
protected Pair<EntityFolder, EntityFolder> onExecute(Context context, Bundle args) throws Throwable {
|
||||||
try {
|
long account = args.getLong("account");
|
||||||
final Context context = getContext();
|
|
||||||
|
|
||||||
int order = 1;
|
DB db = DB.getInstance(context);
|
||||||
PopupMenuLifecycle popupMenu = new PopupMenuLifecycle(context, getViewLifecycleOwner(), anchor);
|
return new Pair(
|
||||||
|
db.folder().getFolderByType(account, EntityFolder.ARCHIVE),
|
||||||
if (message.ui_seen)
|
db.folder().getFolderByType(account, EntityFolder.TRASH));
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_unseen, order++, R.string.title_unseen)
|
|
||||||
.setIcon(R.drawable.twotone_mail_24);
|
|
||||||
else
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_seen, order++, R.string.title_seen)
|
|
||||||
.setIcon(R.drawable.twotone_drafts_24);
|
|
||||||
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_snooze, order++, R.string.title_snooze)
|
|
||||||
.setIcon(R.drawable.twotone_timelapse_24);
|
|
||||||
|
|
||||||
if (message.ui_snoozed == null)
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_hide, order++, R.string.title_hide)
|
|
||||||
.setIcon(R.drawable.twotone_visibility_off_24);
|
|
||||||
else if (message.ui_snoozed == Long.MAX_VALUE)
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_unhide, order++, R.string.title_unhide)
|
|
||||||
.setIcon(R.drawable.twotone_visibility_24);
|
|
||||||
|
|
||||||
if (message.ui_flagged)
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_unflag, order++, R.string.title_unflag)
|
|
||||||
.setIcon(R.drawable.twotone_star_border_24);
|
|
||||||
else
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_flag, order++, R.string.title_flag)
|
|
||||||
.setIcon(R.drawable.twotone_star_24);
|
|
||||||
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_flag_color, order++, R.string.title_flag_color)
|
|
||||||
.setIcon(R.drawable.twotone_auto_awesome_24);
|
|
||||||
|
|
||||||
SubMenu importance = popupMenu.getMenu()
|
|
||||||
.addSubMenu(Menu.NONE, Menu.NONE, order++, R.string.title_set_importance)
|
|
||||||
.setIcon(R.drawable.twotone_north_24);
|
|
||||||
importance.add(Menu.NONE, R.string.title_importance_high, 1, R.string.title_importance_high)
|
|
||||||
.setIcon(R.drawable.twotone_north_24)
|
|
||||||
.setEnabled(!EntityMessage.PRIORITIY_HIGH.equals(message.importance));
|
|
||||||
importance.add(Menu.NONE, R.string.title_importance_normal, 2, R.string.title_importance_normal)
|
|
||||||
.setIcon(R.drawable.twotone_horizontal_rule_24)
|
|
||||||
.setEnabled(!EntityMessage.PRIORITIY_NORMAL.equals(message.importance));
|
|
||||||
importance.add(Menu.NONE, R.string.title_importance_low, 3, R.string.title_importance_low)
|
|
||||||
.setIcon(R.drawable.twotone_south_24)
|
|
||||||
.setEnabled(!EntityMessage.PRIORITIY_LOW.equals(message.importance));
|
|
||||||
|
|
||||||
if (AI.isAvailable(context))
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_summarize, order++, R.string.title_summarize)
|
|
||||||
.setIcon(R.drawable.twotone_smart_toy_24);
|
|
||||||
|
|
||||||
if (message.accountProtocol == EntityAccount.TYPE_IMAP) {
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_move, order++, R.string.title_move)
|
|
||||||
.setIcon(R.drawable.twotone_drive_file_move_24);
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_report_spam, order++, R.string.title_report_spam)
|
|
||||||
.setIcon(R.drawable.twotone_report_24);
|
|
||||||
}
|
|
||||||
popupMenu.getMenu().add(Menu.NONE, R.string.title_delete_permanently, order++, R.string.title_delete_permanently)
|
|
||||||
.setIcon(R.drawable.twotone_delete_forever_24);
|
|
||||||
|
|
||||||
popupMenu.insertIcons(context);
|
|
||||||
|
|
||||||
popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onMenuItemClick(MenuItem target) {
|
|
||||||
int itemId = target.getItemId();
|
|
||||||
if (itemId == R.string.title_seen) {
|
|
||||||
onActionSeenSelection(true, message.id, false);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_unseen) {
|
|
||||||
onActionSeenSelection(false, message.id, false);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_snooze) {
|
|
||||||
onMenuSnooze();
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_hide || itemId == R.string.title_unhide) {
|
|
||||||
onActionHide(message);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_flag) {
|
|
||||||
onActionFlagSelection(true, Color.TRANSPARENT, message.id, false);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_unflag) {
|
|
||||||
onActionFlagSelection(false, Color.TRANSPARENT, message.id, false);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_flag_color) {
|
|
||||||
onMenuColor();
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_importance_low) {
|
|
||||||
onActionSetImportanceSelection(EntityMessage.PRIORITIY_LOW, message.id, false);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_importance_normal) {
|
|
||||||
onActionSetImportanceSelection(EntityMessage.PRIORITIY_NORMAL, message.id, false);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_importance_high) {
|
|
||||||
onActionSetImportanceSelection(EntityMessage.PRIORITIY_HIGH, message.id, false);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_summarize) {
|
|
||||||
onSwipeSummarize(message);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_move) {
|
|
||||||
onSwipeMove(message);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_report_spam) {
|
|
||||||
onSwipeJunk(message);
|
|
||||||
return true;
|
|
||||||
} else if (itemId == R.string.title_delete_permanently) {
|
|
||||||
onSwipeDelete(message, null);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void onMenuSnooze() {
|
|
||||||
Bundle args = new Bundle();
|
|
||||||
args.putString("title", getString(R.string.title_snooze));
|
|
||||||
args.putLong("account", message.account);
|
|
||||||
args.putString("thread", message.thread);
|
|
||||||
args.putLong("id", message.id);
|
|
||||||
if (message.ui_snoozed != null)
|
|
||||||
args.putLong("time", message.ui_snoozed);
|
|
||||||
args.putBoolean("finish", false);
|
|
||||||
|
|
||||||
FragmentDialogDuration fragment = new FragmentDialogDuration();
|
|
||||||
fragment.setArguments(args);
|
|
||||||
fragment.setTargetFragment(FragmentMessages.this, REQUEST_MESSAGE_SNOOZE);
|
|
||||||
fragment.show(getParentFragmentManager(), "message:snooze");
|
|
||||||
}
|
|
||||||
|
|
||||||
private void onMenuColor() {
|
|
||||||
Bundle args = new Bundle();
|
|
||||||
args.putLong("id", message.id);
|
|
||||||
args.putInt("color", message.color == null ? Color.TRANSPARENT : message.color);
|
|
||||||
args.putString("title", getString(R.string.title_flag_color));
|
|
||||||
args.putBoolean("reset", true);
|
|
||||||
args.putInt("faq", 187);
|
|
||||||
|
|
||||||
FragmentDialogColor fragment = new FragmentDialogColor();
|
|
||||||
fragment.setArguments(args);
|
|
||||||
fragment.setTargetFragment(FragmentMessages.this, REQUEST_MESSAGE_COLOR);
|
|
||||||
fragment.show(getParentFragmentManager(), "message:color");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
popupMenu.show();
|
|
||||||
} catch (Throwable ex) {
|
|
||||||
Log.e(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
@Override
|
||||||
|
protected void onExecuted(Bundle args, Pair<EntityFolder, EntityFolder> data) {
|
||||||
|
// Make sure animations are done
|
||||||
|
rvMessage.post(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
final Context context = getContext();
|
||||||
|
|
||||||
|
int order = 1;
|
||||||
|
PopupMenuLifecycle popupMenu = new PopupMenuLifecycle(context, getViewLifecycleOwner(), anchor);
|
||||||
|
|
||||||
|
if (message.ui_seen)
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_unseen, order++, R.string.title_unseen)
|
||||||
|
.setIcon(R.drawable.twotone_mail_24);
|
||||||
|
else
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_seen, order++, R.string.title_seen)
|
||||||
|
.setIcon(R.drawable.twotone_drafts_24);
|
||||||
|
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_snooze, order++, R.string.title_snooze)
|
||||||
|
.setIcon(R.drawable.twotone_timelapse_24);
|
||||||
|
|
||||||
|
if (message.ui_snoozed == null)
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_hide, order++, R.string.title_hide)
|
||||||
|
.setIcon(R.drawable.twotone_visibility_off_24);
|
||||||
|
else if (message.ui_snoozed == Long.MAX_VALUE)
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_unhide, order++, R.string.title_unhide)
|
||||||
|
.setIcon(R.drawable.twotone_visibility_24);
|
||||||
|
|
||||||
|
if (message.ui_flagged)
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_unflag, order++, R.string.title_unflag)
|
||||||
|
.setIcon(R.drawable.twotone_star_border_24);
|
||||||
|
else
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_flag, order++, R.string.title_flag)
|
||||||
|
.setIcon(R.drawable.twotone_star_24);
|
||||||
|
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_flag_color, order++, R.string.title_flag_color)
|
||||||
|
.setIcon(R.drawable.twotone_auto_awesome_24);
|
||||||
|
|
||||||
|
SubMenu importance = popupMenu.getMenu()
|
||||||
|
.addSubMenu(Menu.NONE, Menu.NONE, order++, R.string.title_set_importance)
|
||||||
|
.setIcon(R.drawable.twotone_north_24);
|
||||||
|
importance.add(Menu.NONE, R.string.title_importance_high, 1, R.string.title_importance_high)
|
||||||
|
.setIcon(R.drawable.twotone_north_24)
|
||||||
|
.setEnabled(!EntityMessage.PRIORITIY_HIGH.equals(message.importance));
|
||||||
|
importance.add(Menu.NONE, R.string.title_importance_normal, 2, R.string.title_importance_normal)
|
||||||
|
.setIcon(R.drawable.twotone_horizontal_rule_24)
|
||||||
|
.setEnabled(!EntityMessage.PRIORITIY_NORMAL.equals(message.importance));
|
||||||
|
importance.add(Menu.NONE, R.string.title_importance_low, 3, R.string.title_importance_low)
|
||||||
|
.setIcon(R.drawable.twotone_south_24)
|
||||||
|
.setEnabled(!EntityMessage.PRIORITIY_LOW.equals(message.importance));
|
||||||
|
|
||||||
|
if (AI.isAvailable(context))
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_summarize, order++, R.string.title_summarize)
|
||||||
|
.setIcon(R.drawable.twotone_smart_toy_24);
|
||||||
|
|
||||||
|
if (data.first != null && data.first.id != null)
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_archive, order++, R.string.title_archive)
|
||||||
|
.setIcon(R.drawable.twotone_archive_24)
|
||||||
|
.setIntent(new Intent().putExtra("folder", data.first.id));
|
||||||
|
if (data.second != null && data.second.id != null)
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_trash, order++, R.string.title_trash)
|
||||||
|
.setIcon(R.drawable.twotone_delete_24)
|
||||||
|
.setIntent(new Intent().putExtra("folder", data.second.id));
|
||||||
|
|
||||||
|
if (message.accountProtocol == EntityAccount.TYPE_IMAP) {
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_move, order++, R.string.title_move)
|
||||||
|
.setIcon(R.drawable.twotone_drive_file_move_24);
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_report_spam, order++, R.string.title_report_spam)
|
||||||
|
.setIcon(R.drawable.twotone_report_24);
|
||||||
|
}
|
||||||
|
popupMenu.getMenu().add(Menu.NONE, R.string.title_delete_permanently, order++, R.string.title_delete_permanently)
|
||||||
|
.setIcon(R.drawable.twotone_delete_forever_24);
|
||||||
|
|
||||||
|
popupMenu.insertIcons(context);
|
||||||
|
|
||||||
|
popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
|
||||||
|
@Override
|
||||||
|
public boolean onMenuItemClick(MenuItem target) {
|
||||||
|
int itemId = target.getItemId();
|
||||||
|
if (itemId == R.string.title_seen) {
|
||||||
|
onActionSeenSelection(true, message.id, false);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_unseen) {
|
||||||
|
onActionSeenSelection(false, message.id, false);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_snooze) {
|
||||||
|
onMenuSnooze();
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_hide || itemId == R.string.title_unhide) {
|
||||||
|
onActionHide(message);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_flag) {
|
||||||
|
onActionFlagSelection(true, Color.TRANSPARENT, message.id, false);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_unflag) {
|
||||||
|
onActionFlagSelection(false, Color.TRANSPARENT, message.id, false);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_flag_color) {
|
||||||
|
onMenuColor();
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_importance_low) {
|
||||||
|
onActionSetImportanceSelection(EntityMessage.PRIORITIY_LOW, message.id, false);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_importance_normal) {
|
||||||
|
onActionSetImportanceSelection(EntityMessage.PRIORITIY_NORMAL, message.id, false);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_importance_high) {
|
||||||
|
onActionSetImportanceSelection(EntityMessage.PRIORITIY_HIGH, message.id, false);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_summarize) {
|
||||||
|
onSwipeSummarize(message);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_archive || itemId == R.string.title_trash) {
|
||||||
|
Intent intent = target.getIntent();
|
||||||
|
long folder = (intent == null ? -1L : intent.getLongExtra("folder", -1L));
|
||||||
|
if (folder < 0)
|
||||||
|
return false;
|
||||||
|
swipeFolder(message, folder);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_move) {
|
||||||
|
onSwipeMove(message);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_report_spam) {
|
||||||
|
onSwipeJunk(message);
|
||||||
|
return true;
|
||||||
|
} else if (itemId == R.string.title_delete_permanently) {
|
||||||
|
onSwipeDelete(message, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onMenuSnooze() {
|
||||||
|
Bundle args = new Bundle();
|
||||||
|
args.putString("title", getString(R.string.title_snooze));
|
||||||
|
args.putLong("account", message.account);
|
||||||
|
args.putString("thread", message.thread);
|
||||||
|
args.putLong("id", message.id);
|
||||||
|
if (message.ui_snoozed != null)
|
||||||
|
args.putLong("time", message.ui_snoozed);
|
||||||
|
args.putBoolean("finish", false);
|
||||||
|
|
||||||
|
FragmentDialogDuration fragment = new FragmentDialogDuration();
|
||||||
|
fragment.setArguments(args);
|
||||||
|
fragment.setTargetFragment(FragmentMessages.this, REQUEST_MESSAGE_SNOOZE);
|
||||||
|
fragment.show(getParentFragmentManager(), "message:snooze");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onMenuColor() {
|
||||||
|
Bundle args = new Bundle();
|
||||||
|
args.putLong("id", message.id);
|
||||||
|
args.putInt("color", message.color == null ? Color.TRANSPARENT : message.color);
|
||||||
|
args.putString("title", getString(R.string.title_flag_color));
|
||||||
|
args.putBoolean("reset", true);
|
||||||
|
args.putInt("faq", 187);
|
||||||
|
|
||||||
|
FragmentDialogColor fragment = new FragmentDialogColor();
|
||||||
|
fragment.setArguments(args);
|
||||||
|
fragment.setTargetFragment(FragmentMessages.this, REQUEST_MESSAGE_COLOR);
|
||||||
|
fragment.show(getParentFragmentManager(), "message:color");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
popupMenu.show();
|
||||||
|
} catch (Throwable ex) {
|
||||||
|
Log.e(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onException(Bundle args, Throwable ex) {
|
||||||
|
Log.unexpectedError(getParentFragment(), ex);
|
||||||
|
}
|
||||||
|
}.execute(FragmentMessages.this, args, "swipe:ask");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onSwipeSnooze(TupleMessageEx message, RecyclerView.ViewHolder viewHolder) {
|
private void onSwipeSnooze(TupleMessageEx message, RecyclerView.ViewHolder viewHolder) {
|
||||||
|
|
Loading…
Reference in a new issue