diff --git a/app/src/main/java/eu/faircode/email/EditTextMultiAutoComplete.java b/app/src/main/java/eu/faircode/email/EditTextMultiAutoComplete.java index 0e643207e0..4842d9d9f3 100644 --- a/app/src/main/java/eu/faircode/email/EditTextMultiAutoComplete.java +++ b/app/src/main/java/eu/faircode/email/EditTextMultiAutoComplete.java @@ -32,6 +32,7 @@ import android.text.TextWatcher; import android.text.style.DynamicDrawableSpan; import android.text.style.ImageSpan; import android.util.AttributeSet; +import android.util.DisplayMetrics; import android.view.ContextThemeWrapper; import android.view.MotionEvent; @@ -74,6 +75,7 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie dark ? R.style.Base_Theme_Material3_Dark : R.style.Base_Theme_Material3_Light); ContentResolver resolver = context.getContentResolver(); int dp3 = Helper.dp2pixels(context, 3); + DisplayMetrics dm = getResources().getDisplayMetrics(); addTextChangedListener(new TextWatcher() { @Override @@ -89,8 +91,8 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie @Override public void afterTextChanged(Editable edit) { boolean added = false; - List spans = new ArrayList<>(); - spans.addAll(Arrays.asList(edit.getSpans(0, edit.length(), ImageSpan.class))); + List spans = new ArrayList<>(); + spans.addAll(Arrays.asList(edit.getSpans(0, edit.length(), ClipImageSpan.class))); boolean quote = false; int start = 0; @@ -100,7 +102,7 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie quote = !quote; else if (kar == ',' && !quote) { boolean found = false; - for (ImageSpan span : new ArrayList<>(spans)) { + for (ClipImageSpan span : new ArrayList<>(spans)) { int s = edit.getSpanStart(span); int e = edit.getSpanEnd(span); if (s == start && e == i + 1) { @@ -131,25 +133,19 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie avatar = Drawable.createFromStream(is, email); } - ChipDrawable cd = ChipDrawable.createFromResource(ctx, R.xml.chip); - cd.setChipIcon(avatar); - cd.setCloseIcon(null); - cd.setTextStartPadding(dp3); - cd.setTextEndPadding(dp3); - String e = parsed[0].getAddress(); String p = parsed[0].getPersonal(); - if (TextUtils.isEmpty(p)) - if (TextUtils.isEmpty(e)) - cd.setText(email); - else - cd.setText(e); - else - cd.setText(p); + String text = (TextUtils.isEmpty(p) ? e : p); + // https://github.com/material-components/material-components-android/blob/master/docs/components/Chip.md + ChipDrawable cd = ChipDrawable.createFromResource(ctx, R.xml.chip); + cd.setChipIcon(avatar); + // cd.setLayoutDirection(View.LAYOUT_DIRECTION_LOCALE); + cd.setText(text); + cd.setMaxWidth(2 * dm.widthPixels / 3); cd.setBounds(0, 0, cd.getIntrinsicWidth(), cd.getIntrinsicHeight()); - ImageSpan is = new ImageSpan(cd, DynamicDrawableSpan.ALIGN_BOTTOM); + ClipImageSpan is = new ClipImageSpan(cd); edit.setSpan(is, start, i + 1, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); added = true; } @@ -162,7 +158,7 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie } } - for (ImageSpan span : spans) + for (ClipImageSpan span : spans) edit.removeSpan(span); if (spans.size() > 0 || added) @@ -172,6 +168,12 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie } } + private static class ClipImageSpan extends ImageSpan { + public ClipImageSpan(@NonNull Drawable drawable) { + super(drawable, DynamicDrawableSpan.ALIGN_BOTTOM); + } + } + @Override public boolean onPreDraw() { try { diff --git a/app/src/main/res/xml/chip.xml b/app/src/main/res/xml/chip.xml index b1662e3c27..4032d22b8a 100644 --- a/app/src/main/res/xml/chip.xml +++ b/app/src/main/res/xml/chip.xml @@ -1,5 +1,7 @@ + android:textAppearance="@style/TextAppearance.AppCompat.Small" + app:closeIconVisible="false" + app:textEndPadding="3dp" + app:textStartPadding="3dp" />