Correctly display "no messages"

pull/147/head
M66B 6 years ago
parent a7c3dac2fd
commit ec96c352ee

@ -32,6 +32,7 @@ import androidx.paging.PagedList;
public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMessageEx> { public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMessageEx> {
private ViewModelBrowse model; private ViewModelBrowse model;
private Handler handler; private Handler handler;
private boolean loading = false;
private IBoundaryCallbackMessages intf; private IBoundaryCallbackMessages intf;
private ExecutorService executor = Executors.newSingleThreadExecutor(Helper.backgroundThreadFactory); private ExecutorService executor = Executors.newSingleThreadExecutor(Helper.backgroundThreadFactory);
@ -86,6 +87,7 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
return; return;
try { try {
loading = true;
fetched = 0; fetched = 0;
handler.post(new Runnable() { handler.post(new Runnable() {
@Override @Override
@ -103,6 +105,7 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
} }
}); });
} finally { } finally {
loading = false;
handler.post(new Runnable() { handler.post(new Runnable() {
@Override @Override
public void run() { public void run() {
@ -113,4 +116,8 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
} }
}); });
} }
boolean isLoading() {
return loading;
}
} }

@ -37,6 +37,10 @@ public class ContentLoadingProgressBar extends ProgressBar {
@Override @Override
public void setVisibility(int visibility) { public void setVisibility(int visibility) {
if (false && BuildConfig.DEBUG) {
super.setVisibility(visibility);
return;
}
removeCallbacks(delayedShow); removeCallbacks(delayedShow);
if (visibility == VISIBLE) { if (visibility == VISIBLE) {
super.setVisibility(INVISIBLE); super.setVisibility(INVISIBLE);

@ -1748,18 +1748,18 @@ public class FragmentMessages extends FragmentBase {
new BoundaryCallbackMessages.IBoundaryCallbackMessages() { new BoundaryCallbackMessages.IBoundaryCallbackMessages() {
@Override @Override
public void onLoading() { public void onLoading() {
pbWait.setTag(true);
tvNoEmail.setVisibility(View.GONE);
pbWait.setVisibility(View.VISIBLE); pbWait.setVisibility(View.VISIBLE);
} }
@Override @Override
public void onLoaded(int fetched) { public void onLoaded(int fetched) {
RecyclerView.Adapter adapter = rvMessage.getAdapter();
int items = (adapter == null ? 0 : adapter.getItemCount());
tvNoEmail.setVisibility(items + fetched == 0 ? View.VISIBLE : View.GONE);
pbWait.setVisibility(View.GONE); pbWait.setVisibility(View.GONE);
pbWait.setTag(null);
Integer submitted = (Integer) rvMessage.getTag();
if (submitted == null)
submitted = 0;
if (submitted + fetched == 0)
tvNoEmail.setVisibility(View.VISIBLE);
} }
@Override @Override
@ -2018,13 +2018,14 @@ public class FragmentMessages extends FragmentBase {
Log.i("Submit messages=" + messages.size()); Log.i("Submit messages=" + messages.size());
adapter.submitList(messages); adapter.submitList(messages);
rvMessage.setTag(messages.size());
if (pbWait.getTag() == null) { if (boundaryCallback == null || !boundaryCallback.isLoading())
pbWait.setVisibility(View.GONE); pbWait.setVisibility(View.GONE);
if (!(viewType == AdapterMessage.ViewType.FOLDER || viewType == AdapterMessage.ViewType.SEARCH)) if (boundaryCallback == null && messages.size() == 0)
tvNoEmail.setVisibility(messages.size() == 0 ? View.VISIBLE : View.GONE); tvNoEmail.setVisibility(View.VISIBLE);
grpReady.setVisibility(messages.size() > 0 ? View.VISIBLE : View.GONE); if (messages.size() > 0)
} grpReady.setVisibility(View.VISIBLE);
} }
}; };

Loading…
Cancel
Save