Recreate menu when collapsing search view

pull/820/head
Alex Baker 5 years ago
parent 46e56ddbf7
commit 8731e2fb81

@ -285,19 +285,20 @@ public final class TaskListFragment extends InjectingFragment
toolbar.setTitle(filter.listingTitle); toolbar.setTitle(filter.listingTitle);
toolbar.setNavigationIcon(R.drawable.ic_outline_menu_24px); toolbar.setNavigationIcon(R.drawable.ic_outline_menu_24px);
toolbar.setNavigationOnClickListener(v -> callbacks.onNavigationIconClicked()); toolbar.setNavigationOnClickListener(v -> callbacks.onNavigationIconClicked());
setupMenu(toolbar); setupMenu();
toolbar.setOnMenuItemClickListener(this); toolbar.setOnMenuItemClickListener(this);
MenuColorizer.colorToolbar(context, toolbar); MenuColorizer.colorToolbar(context, toolbar);
return parent; return parent;
} }
private void setupMenu(Toolbar toolbar) { private void setupMenu() {
Menu menu = toolbar.getMenu();
menu.clear();
toolbar.inflateMenu(R.menu.menu_task_list_fragment); toolbar.inflateMenu(R.menu.menu_task_list_fragment);
if (filter.hasMenu()) { if (filter.hasMenu()) {
toolbar.inflateMenu(filter.getMenu()); toolbar.inflateMenu(filter.getMenu());
} }
Menu menu = toolbar.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)) { if (preferences.getBoolean(R.string.p_show_hidden_tasks, false)) {
hidden.setChecked(true); hidden.setChecked(true);
@ -313,8 +314,7 @@ public final class TaskListFragment extends InjectingFragment
hidden.setEnabled(false); hidden.setEnabled(false);
} }
MenuItem voice = menu.findItem(R.id.menu_voice_add); menu.findItem(R.id.menu_voice_add).setVisible(device.voiceInputAvailable());
voice.setVisible(device.voiceInputAvailable());
search = search =
menu.findItem(R.id.menu_search) menu.findItem(R.id.menu_search)
@ -338,10 +338,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();
for (int i = 0; i < menu.size(); i++) { setupMenu();
menu.getItem(i).setVisible(true);
}
voice.setVisible(device.voiceInputAvailable());
return true; return true;
} }
}); });

Loading…
Cancel
Save