1
0
Fork 0
mirror of https://github.com/M66B/FairEmail.git synced 2024-12-27 18:27:43 +00:00

Hide compose/reply FAB on scrolling

This commit is contained in:
M66B 2020-07-10 08:28:52 +02:00
parent d8db9d1836
commit 2ffe1d6cfd

View file

@ -285,6 +285,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
private boolean initialized = false;
private boolean loading = false;
private boolean swiping = false;
private boolean scrolling = false;
private AdapterMessage adapter;
@ -692,6 +693,28 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
};
rvMessage.addItemDecoration(dateDecorator);
rvMessage.addOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(@NonNull RecyclerView recyclerView, int newState) {
if (newState == RecyclerView.SCROLL_STATE_IDLE) {
scrolling = false;
if (viewType == AdapterMessage.ViewType.UNIFIED || viewType == AdapterMessage.ViewType.FOLDER)
fabCompose.show();
updateExpanded();
}
}
@Override
public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) {
if (dy != 0) {
scrolling = true;
if (viewType == AdapterMessage.ViewType.UNIFIED || viewType == AdapterMessage.ViewType.FOLDER)
fabCompose.hide();
updateExpanded();
}
}
});
boolean compact = prefs.getBoolean("compact", false);
int zoom = prefs.getInt("view_zoom", compact ? 0 : 1);
String sort = prefs.getString("sort", "time");
@ -4399,7 +4422,9 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
private void updateExpanded() {
int expanded = (values.containsKey("expanded") ? values.get("expanded").size() : 0);
if (scrolling)
fabReply.hide();
else {
if (expanded == 1) {
long id = values.get("expanded").get(0);
int pos = adapter.getPositionForKey(id);
@ -4410,6 +4435,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
fabReply.hide();
} else
fabReply.hide();
}
ibDown.setVisibility(quick_scroll && expanded > 0 ? View.VISIBLE : View.GONE);
ibUp.setVisibility(quick_scroll && expanded > 0 ? View.VISIBLE : View.GONE);