|
|
@ -1036,7 +1036,7 @@ public class AdapterMessage extends RecyclerView.Adapter<AdapterMessage.ViewHold
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Contact info
|
|
|
|
// Contact info
|
|
|
|
ContactInfo info = ContactInfo.get(context, message.account, addresses, true);
|
|
|
|
ContactInfo[] info = ContactInfo.getCached(context, message.account, addresses);
|
|
|
|
if (info == null) {
|
|
|
|
if (info == null) {
|
|
|
|
if (taskContactInfo != null)
|
|
|
|
if (taskContactInfo != null)
|
|
|
|
taskContactInfo.cancel(context);
|
|
|
|
taskContactInfo.cancel(context);
|
|
|
@ -1046,17 +1046,17 @@ public class AdapterMessage extends RecyclerView.Adapter<AdapterMessage.ViewHold
|
|
|
|
aargs.putLong("account", message.account);
|
|
|
|
aargs.putLong("account", message.account);
|
|
|
|
aargs.putSerializable("addresses", addresses);
|
|
|
|
aargs.putSerializable("addresses", addresses);
|
|
|
|
|
|
|
|
|
|
|
|
taskContactInfo = new SimpleTask<ContactInfo>() {
|
|
|
|
taskContactInfo = new SimpleTask<ContactInfo[]>() {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
protected ContactInfo onExecute(Context context, Bundle args) {
|
|
|
|
protected ContactInfo[] onExecute(Context context, Bundle args) {
|
|
|
|
long account = args.getLong("account");
|
|
|
|
long account = args.getLong("account");
|
|
|
|
Address[] addresses = (Address[]) args.getSerializable("addresses");
|
|
|
|
Address[] addresses = (Address[]) args.getSerializable("addresses");
|
|
|
|
|
|
|
|
|
|
|
|
return ContactInfo.get(context, account, addresses, false);
|
|
|
|
return ContactInfo.get(context, account, addresses);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
protected void onExecuted(Bundle args, ContactInfo info) {
|
|
|
|
protected void onExecuted(Bundle args, ContactInfo[] info) {
|
|
|
|
taskContactInfo = null;
|
|
|
|
taskContactInfo = null;
|
|
|
|
|
|
|
|
|
|
|
|
long id = args.getLong("id");
|
|
|
|
long id = args.getLong("id");
|
|
|
@ -1207,33 +1207,40 @@ public class AdapterMessage extends RecyclerView.Adapter<AdapterMessage.ViewHold
|
|
|
|
ibFlagged.setVisibility(View.GONE);
|
|
|
|
ibFlagged.setVisibility(View.GONE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void bindContactInfo(ContactInfo info, Address[] addresses, boolean name_email) {
|
|
|
|
private void bindContactInfo(ContactInfo[] info, Address[] addresses, boolean name_email) {
|
|
|
|
if (info.hasPhoto()) {
|
|
|
|
if (info[0].hasPhoto()) {
|
|
|
|
ibAvatar.setImageBitmap(info.getPhotoBitmap());
|
|
|
|
ibAvatar.setImageBitmap(info[0].getPhotoBitmap());
|
|
|
|
ibAvatar.setVisibility(View.VISIBLE);
|
|
|
|
ibAvatar.setVisibility(View.VISIBLE);
|
|
|
|
} else
|
|
|
|
} else
|
|
|
|
ibAvatar.setVisibility(View.GONE);
|
|
|
|
ibAvatar.setVisibility(View.GONE);
|
|
|
|
|
|
|
|
|
|
|
|
Uri lookupUri = info.getLookupUri();
|
|
|
|
Uri lookupUri = info[0].getLookupUri();
|
|
|
|
ibAvatar.setTag(lookupUri);
|
|
|
|
ibAvatar.setTag(lookupUri);
|
|
|
|
ibAvatar.setEnabled(lookupUri != null);
|
|
|
|
ibAvatar.setEnabled(lookupUri != null);
|
|
|
|
|
|
|
|
|
|
|
|
String displayName = info.getDisplayName();
|
|
|
|
boolean known = false;
|
|
|
|
if (!TextUtils.isEmpty(displayName) &&
|
|
|
|
boolean updated = false;
|
|
|
|
addresses != null && addresses.length == 1) {
|
|
|
|
for (int i = 0; i < info.length; i++) {
|
|
|
|
String email = ((InternetAddress) addresses[0]).getAddress();
|
|
|
|
if (info[i].isKnown())
|
|
|
|
String personal = ((InternetAddress) addresses[0]).getPersonal();
|
|
|
|
known = true;
|
|
|
|
if (TextUtils.isEmpty(personal) ||
|
|
|
|
String displayName = info[i].getDisplayName();
|
|
|
|
(prefer_contact && !personal.equals(displayName)))
|
|
|
|
if (!TextUtils.isEmpty(displayName)) {
|
|
|
|
try {
|
|
|
|
String email = ((InternetAddress) addresses[i]).getAddress();
|
|
|
|
InternetAddress a = new InternetAddress(email, displayName, StandardCharsets.UTF_8.name());
|
|
|
|
String personal = ((InternetAddress) addresses[i]).getPersonal();
|
|
|
|
tvFrom.setText(MessageHelper.formatAddresses(new Address[]{a}, name_email, false));
|
|
|
|
if (TextUtils.isEmpty(personal) ||
|
|
|
|
} catch (UnsupportedEncodingException ex) {
|
|
|
|
(prefer_contact && !personal.equals(displayName)))
|
|
|
|
Log.w(ex);
|
|
|
|
try {
|
|
|
|
}
|
|
|
|
addresses[i] = new InternetAddress(email, displayName, StandardCharsets.UTF_8.name());
|
|
|
|
|
|
|
|
updated = true;
|
|
|
|
|
|
|
|
} catch (UnsupportedEncodingException ex) {
|
|
|
|
|
|
|
|
Log.w(ex);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (updated)
|
|
|
|
|
|
|
|
tvFrom.setText(MessageHelper.formatAddresses(addresses, name_email, false));
|
|
|
|
|
|
|
|
|
|
|
|
if (distinguish_contacts && info.isKnown())
|
|
|
|
if (distinguish_contacts && known)
|
|
|
|
tvFrom.setPaintFlags(tvFrom.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG);
|
|
|
|
tvFrom.setPaintFlags(tvFrom.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|