Added option to disable partial words search after FTS

pull/213/head
M66B 1 year ago
parent 747414a60b
commit c9b0d0ae4a

@ -108,6 +108,8 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
interface IBoundaryCallbackMessages { interface IBoundaryCallbackMessages {
void onLoading(); void onLoading();
void onScan();
void onLoaded(int found); void onLoaded(int found);
void onWarning(String message); void onWarning(String message);
@ -325,8 +327,19 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
db.endTransaction(); db.endTransaction();
} }
if (state.ids.size() > 0) SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
boolean fts_fallback = prefs.getBoolean("fts_fallback", true);
if (!fts_fallback || state.ids.size() > 0 || state.matches != null)
return found; return found;
else
ApplicationEx.getMainHandler().post(new Runnable() {
@Override
public void run() {
if (intf != null)
intf.onScan();
}
});
} }
while (found < pageSize && !state.destroyed) { while (found < pageSize && !state.destroyed) {

@ -365,6 +365,7 @@ public class FragmentMessages extends FragmentBase
private boolean reset = false; private boolean reset = false;
private boolean initialized = false; private boolean initialized = false;
private boolean loading = false; private boolean loading = false;
private boolean scan = false;
private boolean swiping = false; private boolean swiping = false;
private boolean scrolling = false; private boolean scrolling = false;
private boolean navigating = false; private boolean navigating = false;
@ -6862,6 +6863,7 @@ public class FragmentMessages extends FragmentBase
initialized = false; initialized = false;
loading = false; loading = false;
scan = false;
vmodel.setCallback(getViewLifecycleOwner(), callback); vmodel.setCallback(getViewLifecycleOwner(), callback);
vmodel.setObserver(getViewLifecycleOwner(), observer); vmodel.setObserver(getViewLifecycleOwner(), observer);
} }
@ -6870,9 +6872,15 @@ public class FragmentMessages extends FragmentBase
@Override @Override
public void onLoading() { public void onLoading() {
loading = true; loading = true;
scan = false;
updateListState("Loading", SimpleTask.getCount(), adapter == null ? 0 : adapter.getItemCount()); updateListState("Loading", SimpleTask.getCount(), adapter == null ? 0 : adapter.getItemCount());
} }
public void onScan() {
scan = true;
updateListState("Scan", SimpleTask.getCount(), adapter == null ? 0 : adapter.getItemCount());
}
@Override @Override
public void onLoaded(int found) { public void onLoaded(int found) {
loading = false; loading = false;
@ -6988,12 +6996,18 @@ public class FragmentMessages extends FragmentBase
(language_detection && !TextUtils.isEmpty(filter_language) && !outbox)); (language_detection && !TextUtils.isEmpty(filter_language) && !outbox));
boolean none = (items == 0 && initialized); boolean none = (items == 0 && initialized);
boolean partial = (viewType == AdapterMessage.ViewType.SEARCH && !server && loading && scan && items == 0);
boolean searching = (viewType == AdapterMessage.ViewType.SEARCH && server && (!initialized || loading) && items == 0); boolean searching = (viewType == AdapterMessage.ViewType.SEARCH && server && (!initialized || loading) && items == 0);
boolean filtered = (filter_active && viewType != AdapterMessage.ViewType.SEARCH); boolean filtered = (filter_active && viewType != AdapterMessage.ViewType.SEARCH);
pbWait.setVisibility(loading || tasks > 0 ? View.VISIBLE : View.GONE); pbWait.setVisibility(loading || tasks > 0 ? View.VISIBLE : View.GONE);
tvNoEmail.setText(searching ? R.string.title_search_server_wait : R.string.title_no_messages); if (partial)
tvNoEmail.setVisibility(none || searching ? View.VISIBLE : View.GONE); tvNoEmail.setText(R.string.title_search_device_scan);
else if (searching)
tvNoEmail.setText(R.string.title_search_server_wait);
else
tvNoEmail.setText(R.string.title_no_messages);
tvNoEmail.setVisibility(none || scan || searching ? View.VISIBLE : View.GONE);
tvNoEmailHint.setVisibility(none && filtered ? View.VISIBLE : View.GONE); tvNoEmailHint.setVisibility(none && filtered ? View.VISIBLE : View.GONE);
if (BuildConfig.DEBUG) if (BuildConfig.DEBUG)
@ -7001,8 +7015,11 @@ public class FragmentMessages extends FragmentBase
Log.i("List state who=" + Helper.getWho(this) + "" + Log.i("List state who=" + Helper.getWho(this) + "" +
" reason=" + reason + " reason=" + reason +
" tasks=" + tasks + " loading=" + loading + " tasks=" + tasks +
" items=" + items + " initialized=" + initialized + " initialized=" + initialized +
" loading=" + loading +
" scan=" + scan +
" items=" + items +
" wait=" + (pbWait.getVisibility() == View.VISIBLE) + " wait=" + (pbWait.getVisibility() == View.VISIBLE) +
" no=" + (tvNoEmail.getVisibility() == View.VISIBLE)); " no=" + (tvNoEmail.getVisibility() == View.VISIBLE));
} }

@ -115,6 +115,7 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
private SwitchCompat swExternalAnswer; private SwitchCompat swExternalAnswer;
private SwitchCompat swShortcuts; private SwitchCompat swShortcuts;
private SwitchCompat swFts; private SwitchCompat swFts;
private SwitchCompat swFtsFallback;
private SwitchCompat swClassification; private SwitchCompat swClassification;
private TextView tvClassMinProbability; private TextView tvClassMinProbability;
private SeekBar sbClassMinProbability; private SeekBar sbClassMinProbability;
@ -279,7 +280,7 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
private static final long MIN_FILE_SIZE = 1024 * 1024L; private static final long MIN_FILE_SIZE = 1024 * 1024L;
private final static String[] RESET_OPTIONS = new String[]{ private final static String[] RESET_OPTIONS = new String[]{
"sort_answers", "shortcuts", "fts", "sort_answers", "shortcuts", "fts", "fts_fallback",
"classification", "class_min_probability", "class_min_difference", "classification", "class_min_probability", "class_min_difference",
"show_filtered", "show_filtered",
"language", "language",
@ -368,6 +369,7 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
swExternalAnswer = view.findViewById(R.id.swExternalAnswer); swExternalAnswer = view.findViewById(R.id.swExternalAnswer);
swShortcuts = view.findViewById(R.id.swShortcuts); swShortcuts = view.findViewById(R.id.swShortcuts);
swFts = view.findViewById(R.id.swFts); swFts = view.findViewById(R.id.swFts);
swFtsFallback = view.findViewById(R.id.swFtsFallback);
swClassification = view.findViewById(R.id.swClassification); swClassification = view.findViewById(R.id.swClassification);
ibClassification = view.findViewById(R.id.ibClassification); ibClassification = view.findViewById(R.id.ibClassification);
tvClassMinProbability = view.findViewById(R.id.tvClassMinProbability); tvClassMinProbability = view.findViewById(R.id.tvClassMinProbability);
@ -586,6 +588,7 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
@Override @Override
public void onCheckedChanged(CompoundButton compoundButton, boolean checked) { public void onCheckedChanged(CompoundButton compoundButton, boolean checked) {
prefs.edit().putBoolean("fts", checked).apply(); prefs.edit().putBoolean("fts", checked).apply();
swFtsFallback.setEnabled(checked);
WorkerFts.init(getContext(), true); WorkerFts.init(getContext(), true);
@ -619,6 +622,13 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
} }
}); });
swFtsFallback.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton compoundButton, boolean checked) {
prefs.edit().putBoolean("fts_fallback", checked).apply();
}
});
Helper.linkPro(tvFtsPro); Helper.linkPro(tvFtsPro);
swClassification.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { swClassification.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@ -2472,6 +2482,8 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
swExternalAnswer.setChecked(Helper.isComponentEnabled(getContext(), ActivityAnswer.class)); swExternalAnswer.setChecked(Helper.isComponentEnabled(getContext(), ActivityAnswer.class));
swShortcuts.setChecked(prefs.getBoolean("shortcuts", true)); swShortcuts.setChecked(prefs.getBoolean("shortcuts", true));
swFts.setChecked(prefs.getBoolean("fts", false)); swFts.setChecked(prefs.getBoolean("fts", false));
swFtsFallback.setChecked(prefs.getBoolean("fts_fallback", true));
swFtsFallback.setEnabled(swFts.isChecked());
swClassification.setChecked(prefs.getBoolean("classification", false)); swClassification.setChecked(prefs.getBoolean("classification", false));

@ -179,18 +179,30 @@
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/swFts" /> app:layout_constraintTop_toBottomOf="@id/swFts" />
<androidx.appcompat.widget.SwitchCompat
android:id="@+id/swFtsFallback"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="12dp"
android:layout_marginTop="12dp"
android:text="@string/title_advanced_fts_fallback"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/tvFtsHint"
app:switchPadding="12dp" />
<TextView <TextView
android:id="@+id/tvFtsIndexed" android:id="@+id/tvFtsIndexed"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginTop="6dp" android:layout_marginTop="12dp"
android:layout_marginEnd="48dp" android:layout_marginEnd="48dp"
android:text="@string/title_advanced_fts_indexed" android:text="@string/title_advanced_fts_indexed"
android:textAppearance="@style/TextAppearance.AppCompat.Small" android:textAppearance="@style/TextAppearance.AppCompat.Small"
android:textStyle="italic" android:textStyle="italic"
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/tvFtsHint" /> app:layout_constraintTop_toBottomOf="@id/swFtsFallback" />
<TextView <TextView
android:id="@+id/tvFtsPro" android:id="@+id/tvFtsPro"

@ -811,6 +811,7 @@
<string name="title_advanced_external_answer" translatable="false">Provide reply templates to other apps</string> <string name="title_advanced_external_answer" translatable="false">Provide reply templates to other apps</string>
<string name="title_advanced_shortcuts">Show frequently used contacts in Android share menu</string> <string name="title_advanced_shortcuts">Show frequently used contacts in Android share menu</string>
<string name="title_advanced_fts">Build search index</string> <string name="title_advanced_fts">Build search index</string>
<string name="title_advanced_fts_fallback">Continue with partial word search</string>
<string name="title_advanced_fts_indexed">%1$d / %2$d messages indexed (%3$s)</string> <string name="title_advanced_fts_indexed">%1$d / %2$d messages indexed (%3$s)</string>
<string name="title_advanced_classification">Classify messages</string> <string name="title_advanced_classification">Classify messages</string>
<string name="title_advanced_class_min_chance">Minimum class probability: %1$s %%</string> <string name="title_advanced_class_min_chance">Minimum class probability: %1$s %%</string>
@ -1804,6 +1805,7 @@
<string name="title_search_flag_size">size &gt; %1$s</string> <string name="title_search_flag_size">size &gt; %1$s</string>
<string name="title_search_device">Search on device</string> <string name="title_search_device">Search on device</string>
<string name="title_search_device_scan">Searching with partial words</string>
<string name="title_search_server">Search on server</string> <string name="title_search_server">Search on server</string>
<string name="title_search_server_wait">Waiting for server</string> <string name="title_search_server_wait">Waiting for server</string>
<string name="title_search_in">Search in</string> <string name="title_search_in">Search in</string>

Loading…
Cancel
Save