Added shared email address to open draft

pull/212/head
M66B 2 years ago
parent 6997965336
commit e599942b52

@ -260,11 +260,17 @@ public class ActivityCompose extends ActivityBase implements FragmentManager.OnB
boolean attach_new = prefs.getBoolean("attach_new", true); boolean attach_new = prefs.getBoolean("attach_new", true);
if (!attach_new && !create && if (!attach_new && !create &&
args.size() == 1 && args.containsKey("attachments")) { args.size() == 1 &&
(args.containsKey("to") ||
args.containsKey("attachments"))) {
List<Fragment> fragments = fm.getFragments(); List<Fragment> fragments = fm.getFragments();
if (fragments.size() == 1) { if (fragments.size() == 1 &&
((FragmentCompose) fragments.get(0)).onSharedAttachments( fragments.get(0) instanceof FragmentCompose) {
args.getParcelableArrayList("attachments")); FragmentCompose fragment = ((FragmentCompose) fragments.get(0));
if (args.containsKey("to"))
fragment.onAddTo(args.getString("to"));
else if (args.containsKey("attachments"))
fragment.onSharedAttachments(args.getParcelableArrayList("attachments"));
return; return;
} }
} }

@ -3159,14 +3159,15 @@ public class FragmentCompose extends FragmentBase {
@Override @Override
protected void onExecuted(Bundle args, EntityMessage draft) { protected void onExecuted(Bundle args, EntityMessage draft) {
if (draft == null)
return;
if (requestCode == REQUEST_CONTACT_TO) if (requestCode == REQUEST_CONTACT_TO)
selectIdentityForEmail(args.getString("email")); selectIdentityForEmail(args.getString("email"));
if (draft != null) { etTo.setText(MessageHelper.formatAddressesCompose(draft.to));
etTo.setText(MessageHelper.formatAddressesCompose(draft.to)); etCc.setText(MessageHelper.formatAddressesCompose(draft.cc));
etCc.setText(MessageHelper.formatAddressesCompose(draft.cc)); etBcc.setText(MessageHelper.formatAddressesCompose(draft.bcc));
etBcc.setText(MessageHelper.formatAddressesCompose(draft.bcc));
}
// After showDraft/setFocus // After showDraft/setFocus
view.post(new Runnable() { view.post(new Runnable() {
@ -3203,6 +3204,75 @@ public class FragmentCompose extends FragmentBase {
}.serial().execute(this, args, "compose:picked"); }.serial().execute(this, args, "compose:picked");
} }
void onAddTo(String email) {
Bundle args = new Bundle();
args.putLong("id", working);
args.putString("to", etTo.getText().toString().trim());
args.putString("email", email);
new SimpleTask<EntityMessage>() {
@Override
protected EntityMessage onExecute(Context context, Bundle args) throws Throwable {
long id = args.getLong("id");
String to = args.getString("to");
String email = args.getString("email");
EntityMessage draft;
DB db = DB.getInstance(context);
try {
db.beginTransaction();
draft = db.message().getMessage(id);
if (draft == null)
return null;
List<Address> list = new ArrayList<>();
Address[] _to = MessageHelper.parseAddresses(context, to);
if (_to != null)
list.addAll(Arrays.asList(_to));
list.add(new InternetAddress(email, null, StandardCharsets.UTF_8.name()));
draft.to = list.toArray(new Address[0]);
db.message().updateMessage(draft);
db.setTransactionSuccessful();
} finally {
db.endTransaction();
}
return draft;
}
@Override
protected void onExecuted(Bundle args, EntityMessage draft) {
if (draft == null)
return;
selectIdentityForEmail(args.getString("email"));
etTo.setText(MessageHelper.formatAddressesCompose(draft.to));
// After showDraft/setFocus
view.post(new Runnable() {
@Override
public void run() {
try {
etTo.setSelection(etTo.length());
} catch (Throwable ex) {
Log.e(ex);
}
}
});
}
@Override
protected void onException(Bundle args, Throwable ex) {
Log.unexpectedError(getParentFragmentManager(), ex);
}
}.serial().execute(this, args, "compose:to");
}
@Override @Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
if (pickUri == null) if (pickUri == null)

Loading…
Cancel
Save