mirror of
https://github.com/M66B/FairEmail.git
synced 2026-03-30 21:58:52 +02:00
LanguageTool: check paragraph only on new line
This commit is contained in:
@@ -799,8 +799,13 @@ public class FragmentCompose extends FragmentBase {
|
||||
if (renum)
|
||||
StyleHelper.renumber(text, false, etBody.getContext());
|
||||
|
||||
if (lt_auto)
|
||||
onLanguageTool(true);
|
||||
if (lt_auto) {
|
||||
int start = added;
|
||||
while (start > 0 && text.charAt(start - 1) != '\n')
|
||||
start--;
|
||||
if (start < added)
|
||||
onLanguageTool(start, added, true);
|
||||
}
|
||||
} catch (Throwable ex) {
|
||||
Log.e(ex);
|
||||
} finally {
|
||||
@@ -1968,7 +1973,7 @@ public class FragmentCompose extends FragmentBase {
|
||||
@Override
|
||||
public boolean onLongClick(View v) {
|
||||
if (lt_enabled) {
|
||||
onLanguageTool(false);
|
||||
onLanguageTool(0, etBody.length(), false);
|
||||
return true;
|
||||
} else
|
||||
return false;
|
||||
@@ -2568,13 +2573,13 @@ public class FragmentCompose extends FragmentBase {
|
||||
popupMenu.showWithIcons(context, anchor);
|
||||
}
|
||||
|
||||
private void onLanguageTool(boolean silent) {
|
||||
private void onLanguageTool(int start, int end, boolean silent) {
|
||||
etBody.clearComposingText();
|
||||
|
||||
Log.i("LT running enabled=" + etBody.isSuggestionsEnabled());
|
||||
|
||||
Bundle args = new Bundle();
|
||||
args.putCharSequence("text", etBody.getText());
|
||||
args.putCharSequence("text", etBody.getText().subSequence(start, end));
|
||||
|
||||
new SimpleTask<List<LanguageTool.Suggestion>>() {
|
||||
private Toast toast = null;
|
||||
@@ -2605,7 +2610,7 @@ public class FragmentCompose extends FragmentBase {
|
||||
|
||||
@Override
|
||||
protected void onExecuted(Bundle args, List<LanguageTool.Suggestion> suggestions) {
|
||||
LanguageTool.applySuggestions(etBody, suggestions);
|
||||
LanguageTool.applySuggestions(etBody, start, end, suggestions);
|
||||
|
||||
if (!silent &&
|
||||
(suggestions == null || suggestions.size() == 0))
|
||||
@@ -5692,15 +5697,17 @@ public class FragmentCompose extends FragmentBase {
|
||||
|
||||
Log.i("Draft content=" + draft.content);
|
||||
if (draft.content && state == State.NONE) {
|
||||
Runnable postShow = null;
|
||||
if (args.containsKey("images")) {
|
||||
ArrayList<Uri> images = args.getParcelableArrayList("images");
|
||||
args.remove("images"); // once
|
||||
ArrayList<Uri> images = args.getParcelableArrayList("images");
|
||||
args.remove("images"); // once
|
||||
|
||||
postShow = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
try {
|
||||
Runnable postShow = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
try {
|
||||
if (lt_auto)
|
||||
onLanguageTool(0, etBody.length(), true);
|
||||
|
||||
if (images != null) {
|
||||
boolean image_dialog = prefs.getBoolean("image_dialog", true);
|
||||
if (image_dialog) {
|
||||
Helper.hideKeyboard(view);
|
||||
@@ -5715,12 +5722,12 @@ public class FragmentCompose extends FragmentBase {
|
||||
fragment.show(getParentFragmentManager(), "compose:shared");
|
||||
} else
|
||||
onAddImageFile(images);
|
||||
} catch (Throwable ex) {
|
||||
Log.e(ex);
|
||||
}
|
||||
} catch (Throwable ex) {
|
||||
Log.e(ex);
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
showDraft(draft, false, postShow, args.getInt("selection"));
|
||||
}
|
||||
@@ -6897,9 +6904,6 @@ public class FragmentCompose extends FragmentBase {
|
||||
|
||||
grpBody.setVisibility(View.VISIBLE);
|
||||
|
||||
if (lt_auto)
|
||||
onLanguageTool(true);
|
||||
|
||||
cbSignature.setChecked(draft.signature);
|
||||
tvSignature.setAlpha(draft.signature ? 1.0f : Helper.LOW_LIGHT);
|
||||
|
||||
|
||||
@@ -166,13 +166,13 @@ public class LanguageTool {
|
||||
}
|
||||
}
|
||||
|
||||
static void applySuggestions(EditText etBody, List<Suggestion> suggestions) {
|
||||
static void applySuggestions(EditText etBody, int start, int end, List<Suggestion> suggestions) {
|
||||
Editable edit = etBody.getText();
|
||||
if (edit == null)
|
||||
return;
|
||||
|
||||
// https://developer.android.com/reference/android/text/style/SuggestionSpan
|
||||
for (SuggestionSpanEx suggestion : edit.getSpans(0, edit.length(), SuggestionSpanEx.class)) {
|
||||
for (SuggestionSpanEx suggestion : edit.getSpans(start, end, SuggestionSpanEx.class)) {
|
||||
Log.i("LT removing=" + suggestion);
|
||||
edit.removeSpan(suggestion);
|
||||
}
|
||||
@@ -183,9 +183,13 @@ public class LanguageTool {
|
||||
SuggestionSpan span = new SuggestionSpanEx(etBody.getContext(),
|
||||
suggestion.replacements.toArray(new String[0]),
|
||||
SuggestionSpan.FLAG_MISSPELLED);
|
||||
int start = suggestion.offset;
|
||||
int end = start + suggestion.length;
|
||||
edit.setSpan(span, start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
||||
int s = start + suggestion.offset;
|
||||
int e = s + suggestion.length;
|
||||
if (s < 0 || s > edit.length() || e < 0 || e > edit.length()) {
|
||||
Log.w("LT " + s + "..." + e + " length=" + edit.length());
|
||||
continue;
|
||||
}
|
||||
edit.setSpan(span, s, e, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user