Select again to select email address

pull/198/head
M66B 4 years ago
parent 6a470122b0
commit 20a592c14b

@ -376,15 +376,31 @@ public class FragmentCompose extends FragmentBase {
View.OnTouchListener onTouchListener = new View.OnTouchListener() { View.OnTouchListener onTouchListener = new View.OnTouchListener() {
@Override @Override
public boolean onTouch(View v, MotionEvent event) { public boolean onTouch(View v, MotionEvent event) {
if (event.getAction() == MotionEvent.ACTION_DOWN) {
EditText et = (EditText) v; EditText et = (EditText) v;
int sstart = et.getSelectionStart(); int start = et.getSelectionStart();
int send = et.getSelectionEnd(); int end = et.getSelectionEnd();
if (start < 0 || end < 0)
return false;
if (start == end)
return false;
if (start > end) {
int tmp = start;
start = end;
end = tmp;
}
if (sstart == send && event.getAction() == MotionEvent.ACTION_DOWN) {
float x = event.getX() + et.getScrollX(); float x = event.getX() + et.getScrollX();
float y = event.getY() + et.getScrollY(); float y = event.getY() + et.getScrollY();
int pos = et.getOffsetForPosition(x, y); int pos = et.getOffsetForPosition(x, y);
if (pos >= 0) if (pos < 0)
return false;
// Undo selection to be able to select another address
if (pos < start || pos >= end)
et.setSelection(pos); et.setSelection(pos);
} }
@ -396,20 +412,41 @@ public class FragmentCompose extends FragmentBase {
@Override @Override
public boolean onLongClick(View v) { public boolean onLongClick(View v) {
EditText et = (EditText) v; EditText et = (EditText) v;
int sstart = et.getSelectionStart(); int start = et.getSelectionStart();
int send = et.getSelectionEnd(); int end = et.getSelectionEnd();
String text = et.getText().toString();
if (send < 0 || send > sstart) if (start < 0 || end < 0)
return false; return false;
int ecomma = text.indexOf(',', sstart); if (start > end) {
if (ecomma < 0) int tmp = start;
start = end;
end = tmp;
}
String text = et.getText().toString();
if (text.length() == 0)
return false; return false;
int scomma = text.substring(0, ecomma).lastIndexOf(','); int last = text.indexOf(',', start);
scomma = (scomma < 0 ? 0 : scomma + 1); last = (last < 0 ? text.length() - 1 : last);
et.setSelection(scomma, ecomma + 1);
int first = text.substring(0, last).lastIndexOf(',');
first = (first < 0 ? 0 : first + 1);
if (first == start && last + 1 == end) {
String selected = et.getText().subSequence(start, end).toString();
int gt = selected.lastIndexOf('<');
int lt = selected.lastIndexOf('>');
if (gt >= 0 && lt >= 0 && gt < lt) {
et.setSelection(start + gt + 1, start + lt);
return true;
}
} else {
et.setSelection(first, last + 1);
return true;
}
return false; return false;
} }
}; };

Loading…
Cancel
Save