Completed draft dirty check

pull/147/head
M66B 6 years ago
parent d515f1aafa
commit a5e4b86776

@ -1088,6 +1088,8 @@ public class FragmentCompose extends FragmentEx {
if ("edit".equals(action)) if ("edit".equals(action))
throw new IllegalStateException("Draft not found hide=" + (result.draft != null)); throw new IllegalStateException("Draft not found hide=" + (result.draft != null));
List<EntityIdentity> identities = db.identity().getIdentities();
EntityMessage ref = db.message().getMessage(reference); EntityMessage ref = db.message().getMessage(reference);
if (ref == null) { if (ref == null) {
long aid = args.getLong("account", -1); long aid = args.getLong("account", -1);
@ -1101,8 +1103,6 @@ public class FragmentCompose extends FragmentEx {
result.account = db.account().getAccount(ref.account); result.account = db.account().getAccount(ref.account);
// Reply to recipient, not to known self // Reply to recipient, not to known self
List<EntityIdentity> identities = db.identity().getIdentities();
if (ref.reply != null && ref.reply.length > 0) { if (ref.reply != null && ref.reply.length > 0) {
String reply = Helper.canonicalAddress(((InternetAddress) ref.reply[0]).getAddress()); String reply = Helper.canonicalAddress(((InternetAddress) ref.reply[0]).getAddress());
for (EntityIdentity identity : identities) { for (EntityIdentity identity : identities) {
@ -1177,11 +1177,8 @@ public class FragmentCompose extends FragmentEx {
Log.w(ex); Log.w(ex);
} }
result.draft.subject = args.getString("subject"); result.draft.subject = args.getString("subject", "");
body = args.getString("body"); body = args.getString("body", "");
if (body == null)
body = "";
else
body = body.replaceAll("\\r?\\n", "<br />"); body = body.replaceAll("\\r?\\n", "<br />");
} else { } else {
result.draft.thread = ref.thread; result.draft.thread = ref.thread;
@ -1197,7 +1194,6 @@ public class FragmentCompose extends FragmentEx {
addresses.addAll(Arrays.asList(ref.to)); addresses.addAll(Arrays.asList(ref.to));
if (ref.cc != null) if (ref.cc != null)
addresses.addAll(Arrays.asList(ref.cc)); addresses.addAll(Arrays.asList(ref.cc));
List<EntityIdentity> identities = db.identity().getIdentities();
for (Address address : new ArrayList<>(addresses)) { for (Address address : new ArrayList<>(addresses)) {
String cc = Helper.canonicalAddress(((InternetAddress) address).getAddress()); String cc = Helper.canonicalAddress(((InternetAddress) address).getAddress());
for (EntityIdentity identity : identities) { for (EntityIdentity identity : identities) {
@ -1235,6 +1231,29 @@ public class FragmentCompose extends FragmentEx {
} }
} }
// Select identity matching from address
String from = null;
EntityIdentity primary = null;
if (result.draft.from != null && result.draft.from.length > 0)
from = Helper.canonicalAddress(((InternetAddress) result.draft.from[0]).getAddress());
for (EntityIdentity identity : identities) {
String email = Helper.canonicalAddress(identity.email);
if (email.equals(from)) {
result.draft.identity = identity.id;
result.draft.from = new InternetAddress[]{new InternetAddress(identity.email, identity.name)};
break;
}
if (identity.primary)
primary = identity;
}
// Select primary identity
if (result.draft.identity == null && primary != null) {
result.draft.identity = primary.id;
result.draft.from = new InternetAddress[]{new InternetAddress(primary.email, primary.name)};
}
result.draft.received = new Date().getTime(); result.draft.received = new Date().getTime();
result.draft.setContactInfo(context); result.draft.setContactInfo(context);
@ -1391,39 +1410,15 @@ public class FragmentCompose extends FragmentEx {
adapter.setDropDownViewResource(R.layout.spinner_item1_dropdown); adapter.setDropDownViewResource(R.layout.spinner_item1_dropdown);
spIdentity.setAdapter(adapter); spIdentity.setAdapter(adapter);
boolean found = false; // Select identity
// Select earlier selected identity
if (result.draft.identity != null) if (result.draft.identity != null)
for (int pos = 0; pos < identities.size(); pos++) { for (int pos = 0; pos < identities.size(); pos++) {
if (identities.get(pos).id.equals(result.draft.identity)) { if (identities.get(pos).id.equals(result.draft.identity)) {
spIdentity.setSelection(pos); spIdentity.setSelection(pos);
found = true;
break;
}
}
// Select identity matching from address
if (!found && result.draft.from != null && result.draft.from.length > 0) {
String from = Helper.canonicalAddress(((InternetAddress) result.draft.from[0]).getAddress());
for (int pos = 0; pos < identities.size(); pos++) {
String email = Helper.canonicalAddress(identities.get(pos).email);
if (email.equals(from)) {
spIdentity.setSelection(pos);
found = true;
break; break;
} }
} }
} }
// Select primary identity
if (!found)
for (int pos = 0; pos < identities.size(); pos++)
if (identities.get(pos).primary) {
spIdentity.setSelection(pos);
break;
}
}
}); });
} }

Loading…
Cancel
Save