mirror of https://github.com/M66B/FairEmail.git
Mute refreshing after 45 seconds
This commit is contained in:
parent
ff7ba0e913
commit
11d7b2cb59
|
@ -27,8 +27,10 @@ import androidx.annotation.Nullable;
|
||||||
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
|
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
|
||||||
|
|
||||||
public class SwipeRefreshLayoutEx extends SwipeRefreshLayout {
|
public class SwipeRefreshLayoutEx extends SwipeRefreshLayout {
|
||||||
|
private boolean muted = false;
|
||||||
private boolean refreshing = false;
|
private boolean refreshing = false;
|
||||||
|
|
||||||
|
private static final int DELAY_MUTE = 45 * 1000; // milliseconds
|
||||||
private static final int DELAY_DISABLE = 1500; // milliseconds
|
private static final int DELAY_DISABLE = 1500; // milliseconds
|
||||||
|
|
||||||
public SwipeRefreshLayoutEx(@NonNull Context context) {
|
public SwipeRefreshLayoutEx(@NonNull Context context) {
|
||||||
|
@ -47,12 +49,18 @@ public class SwipeRefreshLayoutEx extends SwipeRefreshLayout {
|
||||||
this.refreshing = refreshing;
|
this.refreshing = refreshing;
|
||||||
|
|
||||||
removeCallbacks(delayedDisable);
|
removeCallbacks(delayedDisable);
|
||||||
|
removeCallbacks(delayedMute);
|
||||||
|
|
||||||
if (refreshing)
|
if (refreshing) {
|
||||||
super.setRefreshing(refreshing);
|
if (!muted) {
|
||||||
else
|
super.setRefreshing(true);
|
||||||
|
postDelayed(delayedMute, DELAY_MUTE);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
muted = false;
|
||||||
postDelayed(delayedDisable, DELAY_DISABLE);
|
postDelayed(delayedDisable, DELAY_DISABLE);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isRefreshing() {
|
public boolean isRefreshing() {
|
||||||
|
@ -60,8 +68,9 @@ public class SwipeRefreshLayoutEx extends SwipeRefreshLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onRefresh() {
|
public void onRefresh() {
|
||||||
|
// User initiated
|
||||||
this.refreshing = true;
|
this.refreshing = true;
|
||||||
setRefreshing(false);
|
setRefreshing(false); // disable, unless confirmed by folder update
|
||||||
}
|
}
|
||||||
|
|
||||||
public void resetRefreshing() {
|
public void resetRefreshing() {
|
||||||
|
@ -79,4 +88,14 @@ public class SwipeRefreshLayoutEx extends SwipeRefreshLayout {
|
||||||
SwipeRefreshLayoutEx.super.setRefreshing(refreshing);
|
SwipeRefreshLayoutEx.super.setRefreshing(refreshing);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private final Runnable delayedMute = new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (refreshing) {
|
||||||
|
muted = true;
|
||||||
|
SwipeRefreshLayoutEx.super.setRefreshing(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue