Mark all read "don't ask again"

pull/197/head
M66B 4 years ago
parent b2481213a0
commit 3a25f87d06

@ -360,6 +360,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
static final int REQUEST_PICK_CONTACT = 23;
static final int REQUEST_BUTTONS = 24;
private static final int REQUEST_ASKED_RAW = 25;
private static final int REQUEST_ALL_READ = 26;
static final String ACTION_STORE_RAW = BuildConfig.APPLICATION_ID + ".STORE_RAW";
static final String ACTION_DECRYPT = BuildConfig.APPLICATION_ID + ".DECRYPT";
@ -4482,11 +4483,25 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
}
private void onMenuMarkAllRead() {
new AlertDialog.Builder(getContext())
.setTitle(R.string.title_mark_all_read)
.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getContext());
boolean all_read_asked = prefs.getBoolean("all_read_asked", false);
if (all_read_asked) {
markAllRead();
return;
}
Bundle args = new Bundle();
args.putString("question", getString(R.string.title_mark_all_read));
args.putString("notagain", "all_read_asked");
FragmentDialogAsk ask = new FragmentDialogAsk();
ask.setArguments(args);
ask.setTargetFragment(FragmentMessages.this, REQUEST_ALL_READ);
ask.show(getParentFragmentManager(), "messages:allread");
}
private void markAllRead() {
Bundle args = new Bundle();
args.putString("type", type);
args.putLong("folder", folder);
@ -4531,11 +4546,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
protected void onException(Bundle args, Throwable ex) {
Log.unexpectedError(getParentFragmentManager(), ex);
}
}.execute(FragmentMessages.this, args, "message:read");
}
})
.setNegativeButton(android.R.string.cancel, null)
.show();
}.execute(FragmentMessages.this, args, "messages:allread");
}
private void onMenuSyncMore() {
@ -6047,6 +6058,10 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
if (resultCode == RESULT_OK)
_onActionRaw();
break;
case REQUEST_ALL_READ:
if (requestCode == RESULT_OK)
markAllRead();
break;
}
} catch (Throwable ex) {
Log.e(ex);

@ -151,7 +151,7 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
"selected_folders", "move_1_confirmed", "move_n_confirmed",
"last_search_senders", "last_search_recipients", "last_search_subject", "last_search_keywords", "last_search_message", "last_search",
"identities_asked", "identities_primary_hint",
"raw_asked",
"raw_asked", "all_read_asked",
"cc_bcc", "inline_image_hint", "compose_reference", "send_dialog",
"setup_reminder", "setup_advanced"
};

Loading…
Cancel
Save