1
0
Fork 0
mirror of https://github.com/M66B/FairEmail.git synced 2025-01-01 04:35:57 +00:00

Style fixes and improvements

This commit is contained in:
M66B 2019-05-01 16:40:39 +02:00
parent 10029366bc
commit 467da4b6d4

View file

@ -369,23 +369,20 @@ public class FragmentCompose extends FragmentBase {
if (item.getGroupId() != 1) if (item.getGroupId() != 1)
return false; return false;
int s = etBody.getSelectionStart(); int start = etBody.getSelectionStart();
int e = etBody.getSelectionEnd(); int end = etBody.getSelectionEnd();
if (s < 0) if (start < 0)
s = 0; start = 0;
if (e < 0) if (end < 0)
e = 0; end = 0;
if (s > e) { if (start > end) {
int tmp = s; int tmp = start;
s = e; start = end;
e = tmp; end = tmp;
} }
final int start = s;
final int end = e;
final SpannableString ss = new SpannableString(etBody.getText()); final SpannableString ss = new SpannableString(etBody.getText());
switch (item.getItemId()) { switch (item.getItemId()) {
@ -442,11 +439,13 @@ public class FragmentCompose extends FragmentBase {
etBody.setText(ss); etBody.setText(ss);
etBody.setSelection(end); etBody.setSelection(end);
return false; return false;
} }
case R.string.title_style_color: { case R.string.title_style_color: {
final int s = start;
final int e = end;
ForegroundColorSpan[] spans = ss.getSpans(start, end, ForegroundColorSpan.class); ForegroundColorSpan[] spans = ss.getSpans(start, end, ForegroundColorSpan.class);
int color = (spans.length > 0 ? spans[0].getForegroundColor() : Color.TRANSPARENT); int color = (spans.length > 0 ? spans[0].getForegroundColor() : Color.TRANSPARENT);
@ -456,11 +455,11 @@ public class FragmentCompose extends FragmentBase {
colorPickerDialog.setOnColorSelectedListener(new ColorPickerSwatch.OnColorSelectedListener() { colorPickerDialog.setOnColorSelectedListener(new ColorPickerSwatch.OnColorSelectedListener() {
@Override @Override
public void onColorSelected(int color) { public void onColorSelected(int color) {
for (ForegroundColorSpan span : ss.getSpans(start, end, ForegroundColorSpan.class)) for (ForegroundColorSpan span : ss.getSpans(s, e, ForegroundColorSpan.class))
ss.removeSpan(span); ss.removeSpan(span);
ss.setSpan(new ForegroundColorSpan(color), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); ss.setSpan(new ForegroundColorSpan(color), s, e, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
etBody.setText(ss); etBody.setText(ss);
etBody.setSelection(end); etBody.setSelection(e);
} }
}); });
colorPickerDialog.show(getFragmentManager(), "colorpicker"); colorPickerDialog.show(getFragmentManager(), "colorpicker");
@ -501,9 +500,8 @@ public class FragmentCompose extends FragmentBase {
public boolean onNavigationItemSelected(@NonNull MenuItem item) { public boolean onNavigationItemSelected(@NonNull MenuItem item) {
int action = item.getItemId(); int action = item.getItemId();
switch (action) { switch (action) {
case R.id.menu_clear:
case R.id.menu_link: case R.id.menu_link:
onMenuStyle(item.getItemId()); onMenuLink();
return true; return true;
case R.id.menu_image: case R.id.menu_image:
onActionImage(); onActionImage();
@ -976,7 +974,7 @@ public class FragmentCompose extends FragmentBase {
onActionAttachment(); onActionAttachment();
return true; return true;
case R.id.menu_clear: case R.id.menu_clear:
onMenuStyle(item.getItemId()); onMenuClear();
return true; return true;
case R.id.menu_contact_group: case R.id.menu_contact_group:
onMenuContactGroup(); onMenuContactGroup();
@ -1031,91 +1029,98 @@ public class FragmentCompose extends FragmentBase {
edit_bar.setVisibility(style ? View.VISIBLE : View.GONE); edit_bar.setVisibility(style ? View.VISIBLE : View.GONE);
} }
private void onMenuStyle(int id) { private void onMenuClear() {
int s = etBody.getSelectionStart(); int end = etBody.getSelectionEnd();
int e = etBody.getSelectionEnd(); if (end < 0)
end = 0;
if (s < 0) SpannableString ss = new SpannableString(etBody.getText());
s = 0;
if (e < 0)
e = 0;
if (s > e) { for (Object span : ss.getSpans(0, ss.length(), Object.class))
int tmp = s; if (!(span instanceof ImageSpan))
s = e; ss.removeSpan(span);
e = tmp;
}
final int start = s;
final int end = e;
final SpannableString ss = new SpannableString(etBody.getText());
switch (id) {
case R.id.menu_clear:
for (Object span : ss.getSpans(0, ss.length(), Object.class))
if (!(span instanceof ImageSpan))
ss.removeSpan(span);
break;
case R.id.menu_link:
Uri uri = null;
ClipboardManager cbm = (ClipboardManager) getContext().getSystemService(Context.CLIPBOARD_SERVICE);
if (cbm.hasPrimaryClip()) {
String link = cbm.getPrimaryClip().getItemAt(0).coerceToText(getContext()).toString();
uri = Uri.parse(link);
if (uri.getScheme() == null)
uri = null;
}
View view = LayoutInflater.from(getContext()).inflate(R.layout.dialog_insert_link, null);
final EditText etLink = view.findViewById(R.id.etLink);
final TextView tvInsecure = view.findViewById(R.id.tvInsecure);
etLink.setText(uri == null ? "https://" : uri.toString());
tvInsecure.setVisibility(View.GONE);
etLink.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
tvInsecure.setVisibility("http".equals(Uri.parse(s.toString()).getScheme()) ? View.VISIBLE : View.GONE);
}
@Override
public void afterTextChanged(Editable s) {
}
});
new DialogBuilderLifecycle(getContext(), getViewLifecycleOwner())
.setView(view)
.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
ss.setSpan(new URLSpan(etLink.getText().toString()), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
etBody.setText(ss);
etBody.setSelection(end);
}
})
.show();
new Handler().post(new Runnable() {
@Override
public void run() {
etLink.requestFocus();
}
});
return;
}
etBody.setText(ss); etBody.setText(ss);
etBody.setSelection(end); etBody.setSelection(end);
} }
private void onMenuLink() {
Uri uri = null;
ClipboardManager cbm = (ClipboardManager) getContext().getSystemService(Context.CLIPBOARD_SERVICE);
if (cbm.hasPrimaryClip()) {
String link = cbm.getPrimaryClip().getItemAt(0).coerceToText(getContext()).toString();
uri = Uri.parse(link);
if (uri.getScheme() == null)
uri = null;
}
View view = LayoutInflater.from(getContext()).inflate(R.layout.dialog_insert_link, null);
final EditText etLink = view.findViewById(R.id.etLink);
final TextView tvInsecure = view.findViewById(R.id.tvInsecure);
etLink.setText(uri == null ? "https://" : uri.toString());
tvInsecure.setVisibility(View.GONE);
etLink.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
tvInsecure.setVisibility("http".equals(Uri.parse(s.toString()).getScheme()) ? View.VISIBLE : View.GONE);
}
@Override
public void afterTextChanged(Editable s) {
}
});
new DialogBuilderLifecycle(getContext(), getViewLifecycleOwner())
.setView(view)
.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
int start = etBody.getSelectionStart();
int end = etBody.getSelectionEnd();
if (start < 0)
start = 0;
if (end < 0)
end = 0;
if (start > end) {
int tmp = start;
start = end;
end = tmp;
}
String link = etLink.getText().toString();
if (start == end) {
etBody.setText(etBody.getText().insert(start, link));
end = start + link.length();
}
SpannableString ss = new SpannableString(etBody.getText());
for (URLSpan span : ss.getSpans(start, end, URLSpan.class))
ss.removeSpan(span);
ss.setSpan(new URLSpan(link), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
etBody.setText(ss);
etBody.setSelection(end);
}
})
.show();
new Handler().post(new Runnable() {
@Override
public void run() {
etLink.requestFocus();
}
});
}
private void onMenuContactGroup() { private void onMenuContactGroup() {
View dview = LayoutInflater.from(getContext()).inflate(R.layout.dialog_contact_group, null); View dview = LayoutInflater.from(getContext()).inflate(R.layout.dialog_contact_group, null);
final ListView lvGroup = dview.findViewById(R.id.lvGroup); final ListView lvGroup = dview.findViewById(R.id.lvGroup);