Distinguish widget from address

pull/194/merge
M66B 3 years ago
parent 89571b7287
commit dda23dbb44

@ -30,6 +30,7 @@ import android.text.SpannableString;
import android.text.Spanned; import android.text.Spanned;
import android.text.TextUtils; import android.text.TextUtils;
import android.text.style.StyleSpan; import android.text.style.StyleSpan;
import android.text.style.UnderlineSpan;
import android.util.TypedValue; import android.util.TypedValue;
import android.view.View; import android.view.View;
import android.widget.RemoteViews; import android.widget.RemoteViews;
@ -62,6 +63,7 @@ public class WidgetUnifiedRemoteViewsFactory implements RemoteViewsService.Remot
private int padding; private int padding;
private boolean prefer_contact; private boolean prefer_contact;
private boolean only_contact; private boolean only_contact;
private boolean distinguish_contacts;
private int colorStripeWidth; private int colorStripeWidth;
private int colorWidgetForeground; private int colorWidgetForeground;
private int colorWidgetRead; private int colorWidgetRead;
@ -101,6 +103,7 @@ public class WidgetUnifiedRemoteViewsFactory implements RemoteViewsService.Remot
padding = prefs.getInt("widget." + appWidgetId + ".padding", 0); padding = prefs.getInt("widget." + appWidgetId + ".padding", 0);
prefer_contact = prefs.getBoolean("prefer_contact", false); prefer_contact = prefs.getBoolean("prefer_contact", false);
only_contact = prefs.getBoolean("only_contact", false); only_contact = prefs.getBoolean("only_contact", false);
distinguish_contacts = prefs.getBoolean("distinguish_contacts", false);
boolean color_stripe_wide = prefs.getBoolean("color_stripe_wide", false); boolean color_stripe_wide = prefs.getBoolean("color_stripe_wide", false);
this.colorStripeWidth = Helper.dp2pixels(context, color_stripe_wide ? 12 : 6); this.colorStripeWidth = Helper.dp2pixels(context, color_stripe_wide ? 12 : 6);
@ -192,6 +195,7 @@ public class WidgetUnifiedRemoteViewsFactory implements RemoteViewsService.Remot
views.setViewVisibility(R.id.stripe, hasColor && color_stripe ? View.VISIBLE : View.GONE); views.setViewVisibility(R.id.stripe, hasColor && color_stripe ? View.VISIBLE : View.GONE);
Address[] recipients = ContactInfo.fillIn(message.from, prefer_contact, only_contact); Address[] recipients = ContactInfo.fillIn(message.from, prefer_contact, only_contact);
boolean known = (distinguish_contacts && ContactInfo.getLookupUri(message.from) != null);
SpannableString ssFrom = new SpannableString(pro SpannableString ssFrom = new SpannableString(pro
? MessageHelper.formatAddressesShort(recipients) ? MessageHelper.formatAddressesShort(recipients)
@ -214,6 +218,9 @@ public class WidgetUnifiedRemoteViewsFactory implements RemoteViewsService.Remot
ssAccount.setSpan(new StyleSpan(Typeface.BOLD), 0, ssAccount.length(), Spanned.SPAN_INCLUSIVE_INCLUSIVE); ssAccount.setSpan(new StyleSpan(Typeface.BOLD), 0, ssAccount.length(), Spanned.SPAN_INCLUSIVE_INCLUSIVE);
} }
if (known)
ssFrom.setSpan(new UnderlineSpan(), 0, ssFrom.length(), Spanned.SPAN_INCLUSIVE_INCLUSIVE);
views.setTextViewText(idFrom, ssFrom); views.setTextViewText(idFrom, ssFrom);
views.setTextViewText(idTime, ssTime); views.setTextViewText(idTime, ssTime);
views.setTextViewText(idSubject, ssSubject); views.setTextViewText(idSubject, ssSubject);

Loading…
Cancel
Save