Save search query on rotate

pull/820/head
Alex Baker 5 years ago
parent f1f7201333
commit 4121f09752

@ -108,6 +108,7 @@ public final class TaskListFragment extends InjectingFragment
public static final String ACTION_DELETED = "action_deleted"; public static final String ACTION_DELETED = "action_deleted";
public static final int REQUEST_MOVE_TASKS = 10103; public static final int REQUEST_MOVE_TASKS = 10103;
private static final String EXTRA_SELECTED_TASK_IDS = "extra_selected_task_ids"; private static final String EXTRA_SELECTED_TASK_IDS = "extra_selected_task_ids";
private static final String EXTRA_SEARCH = "extra_search";
private static final int VOICE_RECOGNITION_REQUEST_CODE = 1234; private static final int VOICE_RECOGNITION_REQUEST_CODE = 1234;
private static final String EXTRA_FILTER = "extra_filter"; private static final String EXTRA_FILTER = "extra_filter";
private static final String FRAG_TAG_SORT_DIALOG = "frag_tag_sort_dialog"; private static final String FRAG_TAG_SORT_DIALOG = "frag_tag_sort_dialog";
@ -158,6 +159,7 @@ public final class TaskListFragment extends InjectingFragment
private PublishSubject<String> searchSubject = PublishSubject.create(); private PublishSubject<String> searchSubject = PublishSubject.create();
private Disposable searchDisposable; private Disposable searchDisposable;
private MenuItem search; private MenuItem search;
private String searchQuery;
private TaskListFragmentCallbackHandler callbacks; private TaskListFragmentCallbackHandler callbacks;
@ -231,6 +233,7 @@ public final class TaskListFragment extends InjectingFragment
List<Long> selectedTaskIds = taskAdapter.getSelected(); List<Long> selectedTaskIds = taskAdapter.getSelected();
outState.putLongArray(EXTRA_SELECTED_TASK_IDS, Longs.toArray(selectedTaskIds)); outState.putLongArray(EXTRA_SELECTED_TASK_IDS, Longs.toArray(selectedTaskIds));
outState.putString(EXTRA_SEARCH, searchQuery);
} }
@Override @Override
@ -248,7 +251,13 @@ public final class TaskListFragment extends InjectingFragment
taskListViewModel = ViewModelProviders.of(getActivity()).get(TaskListViewModel.class); taskListViewModel = ViewModelProviders.of(getActivity()).get(TaskListViewModel.class);
taskListViewModel.setFilter(filter, taskAdapter.isManuallySorted()); if (savedInstanceState != null) {
searchQuery = savedInstanceState.getString(EXTRA_SEARCH);
}
taskListViewModel.setFilter(
searchQuery == null ? filter : createSearchFilter(searchQuery),
taskAdapter.isManuallySorted());
recyclerAdapter = recyclerAdapter =
taskAdapter.isManuallySorted() taskAdapter.isManuallySorted()
@ -307,18 +316,15 @@ public final class TaskListFragment extends InjectingFragment
toolbar.inflateMenu(filter.getMenu()); toolbar.inflateMenu(filter.getMenu());
} }
MenuItem hidden = menu.findItem(R.id.menu_show_hidden); MenuItem hidden = menu.findItem(R.id.menu_show_hidden);
if (preferences.getBoolean(R.string.p_show_hidden_tasks, false)) {
hidden.setChecked(true);
}
MenuItem completed = menu.findItem(R.id.menu_show_completed); MenuItem completed = menu.findItem(R.id.menu_show_completed);
if (preferences.getBoolean(R.string.p_show_completed_tasks, false)) {
completed.setChecked(true);
}
if (!taskAdapter.supportsHiddenTasks() || filter instanceof SearchFilter) { if (!taskAdapter.supportsHiddenTasks() || filter instanceof SearchFilter) {
completed.setChecked(true); completed.setChecked(true);
completed.setEnabled(false); completed.setEnabled(false);
hidden.setChecked(true); hidden.setChecked(true);
hidden.setEnabled(false); hidden.setEnabled(false);
} else {
hidden.setChecked(preferences.getBoolean(R.string.p_show_hidden_tasks, false));
completed.setChecked(preferences.getBoolean(R.string.p_show_completed_tasks, false));
} }
menu.findItem(R.id.menu_voice_add).setVisible(device.voiceInputAvailable()); menu.findItem(R.id.menu_voice_add).setVisible(device.voiceInputAvailable());
@ -335,14 +341,14 @@ public final class TaskListFragment extends InjectingFragment
} }
} }
private void searchByQuery(String query) { private void searchByQuery(@Nullable String query) {
query = query.trim(); searchQuery = query == null ? "" : query.trim();
if (!query.isEmpty()) { if (searchQuery.isEmpty()) {
Filter savedFilter = createSearchFilter(query);
taskListViewModel.searchByFilter(savedFilter);
} else {
taskListViewModel.searchByFilter( taskListViewModel.searchByFilter(
BuiltInFilterExposer.getMyTasksFilter(context.getResources())); BuiltInFilterExposer.getMyTasksFilter(context.getResources()));
} else {
Filter savedFilter = createSearchFilter(searchQuery);
taskListViewModel.searchByFilter(savedFilter);
} }
} }
@ -588,7 +594,9 @@ public final class TaskListFragment extends InjectingFragment
.debounce(SEARCH_DEBOUNCE_TIMEOUT, TimeUnit.MILLISECONDS) .debounce(SEARCH_DEBOUNCE_TIMEOUT, TimeUnit.MILLISECONDS)
.observeOn(AndroidSchedulers.mainThread()) .observeOn(AndroidSchedulers.mainThread())
.subscribe(this::searchByQuery); .subscribe(this::searchByQuery);
if (searchQuery == null) {
searchByQuery(""); searchByQuery("");
}
Menu menu = toolbar.getMenu(); Menu menu = toolbar.getMenu();
for (int i = 0; i < menu.size(); i++) { for (int i = 0; i < menu.size(); i++) {
menu.getItem(i).setVisible(false); menu.getItem(i).setVisible(false);
@ -600,6 +608,7 @@ public final class TaskListFragment extends InjectingFragment
public boolean onMenuItemActionCollapse(MenuItem item) { public boolean onMenuItemActionCollapse(MenuItem item) {
taskListViewModel.searchByFilter(filter); taskListViewModel.searchByFilter(filter);
searchDisposable.dispose(); searchDisposable.dispose();
searchQuery = null;
setupMenu(); setupMenu();
return true; return true;
} }

Loading…
Cancel
Save