Delay swipe refreshing updates

This commit is contained in:
M66B 2020-05-20 13:05:40 +02:00
parent e7defe71e7
commit 19364c717b
3 changed files with 85 additions and 21 deletions

View File

@ -213,7 +213,7 @@ import static org.openintents.openpgp.OpenPgpSignatureResult.RESULT_VALID_KEY_UN
public class FragmentMessages extends FragmentBase implements SharedPreferences.OnSharedPreferenceChangeListener { public class FragmentMessages extends FragmentBase implements SharedPreferences.OnSharedPreferenceChangeListener {
private ViewGroup view; private ViewGroup view;
private SwipeRefreshLayout swipeRefresh; private SwipeRefreshLayoutEx swipeRefresh;
private TextView tvSupport; private TextView tvSupport;
private ImageButton ibHintSupport; private ImageButton ibHintSupport;
private ImageButton ibHintSwipe; private ImageButton ibHintSwipe;
@ -1338,16 +1338,15 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
args.putLong("folder", folder); args.putLong("folder", folder);
args.putString("type", type); args.putString("type", type);
new SimpleTask<Integer>() { new SimpleTask<Void>() {
@Override @Override
protected Integer onExecute(Context context, Bundle args) { protected Void onExecute(Context context, Bundle args) {
long fid = args.getLong("folder"); long fid = args.getLong("folder");
String type = args.getString("type"); String type = args.getString("type");
if (!ConnectionHelper.getNetworkState(context).isSuitable()) if (!ConnectionHelper.getNetworkState(context).isSuitable())
throw new IllegalStateException(context.getString(R.string.title_no_internet)); throw new IllegalStateException(context.getString(R.string.title_no_internet));
int count;
boolean now = true; boolean now = true;
boolean force = false; boolean force = false;
@ -1370,8 +1369,6 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
folders.add(folder); folders.add(folder);
} }
count = folders.size();
for (EntityFolder folder : folders) { for (EntityFolder folder : folders) {
EntityOperation.sync(context, folder.id, true); EntityOperation.sync(context, folder.id, true);
@ -1399,13 +1396,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
if (!now) if (!now)
throw new IllegalArgumentException(context.getString(R.string.title_no_connection)); throw new IllegalArgumentException(context.getString(R.string.title_no_connection));
return count; return null;
}
@Override
protected void onExecuted(Bundle args, Integer count) {
if (count > 0)
swipeRefresh.setRefreshing(true);
} }
@Override @Override
@ -3200,10 +3191,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
adapter.setZoom(zoom); adapter.setZoom(zoom);
// Restart spinner // Restart spinner
if (swipeRefresh.isRefreshing()) { swipeRefresh.resetRefreshing();
swipeRefresh.setRefreshing(false);
swipeRefresh.setRefreshing(true);
}
prefs.registerOnSharedPreferenceChangeListener(this); prefs.registerOnSharedPreferenceChangeListener(this);
onSharedPreferenceChanged(prefs, "pro"); onSharedPreferenceChanged(prefs, "pro");
@ -3872,7 +3860,6 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
else else
fabError.hide(); fabError.hide();
if (refreshing != swipeRefresh.isRefreshing())
swipeRefresh.setRefreshing(refreshing); swipeRefresh.setRefreshing(refreshing);
} }

View File

@ -0,0 +1,77 @@
package eu.faircode.email;
/*
This file is part of FairEmail.
FairEmail is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
FairEmail is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with FairEmail. If not, see <http://www.gnu.org/licenses/>.
Copyright 2018-2020 by Marcel Bokhorst (M66B)
*/
import android.content.Context;
import android.util.AttributeSet;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
public class SwipeRefreshLayoutEx extends SwipeRefreshLayout {
private boolean refreshing = false;
private static final int DELAY_DISABLE = 1000; // milliseconds
public SwipeRefreshLayoutEx(@NonNull Context context) {
super(context);
}
public SwipeRefreshLayoutEx(@NonNull Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
}
@Override
public void setRefreshing(boolean refreshing) {
if (this.refreshing == refreshing)
return;
this.refreshing = refreshing;
removeCallbacks(delayedDisable);
if (refreshing)
super.setRefreshing(refreshing);
else
postDelayed(delayedDisable, DELAY_DISABLE);
}
@Override
public boolean isRefreshing() {
return this.refreshing;
}
public void resetRefreshing() {
// Restart spinner after screen off, etc
if (super.isRefreshing()) {
super.setRefreshing(false);
super.setRefreshing(true);
}
}
private final Runnable delayedDisable = new Runnable() {
@Override
public void run() {
if (!refreshing)
SwipeRefreshLayoutEx.super.setRefreshing(refreshing);
}
};
}

View File

@ -6,7 +6,7 @@
android:layout_height="match_parent" android:layout_height="match_parent"
tools:context="eu.faircode.email.ActivityView"> tools:context="eu.faircode.email.ActivityView">
<androidx.swiperefreshlayout.widget.SwipeRefreshLayout <eu.faircode.email.SwipeRefreshLayoutEx
android:id="@+id/swipeRefresh" android:id="@+id/swipeRefresh"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
@ -325,7 +325,7 @@
android:layout_height="0dp" android:layout_height="0dp"
app:constraint_referenced_ids="rvMessage" /> app:constraint_referenced_ids="rvMessage" />
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>
</androidx.swiperefreshlayout.widget.SwipeRefreshLayout> </eu.faircode.email.SwipeRefreshLayoutEx>
<com.google.android.material.floatingactionbutton.FloatingActionButton <com.google.android.material.floatingactionbutton.FloatingActionButton
android:id="@+id/fabMore" android:id="@+id/fabMore"