mirror of
https://github.com/M66B/FairEmail.git
synced 2025-03-20 02:45:30 +00:00
Diff folder states
This commit is contained in:
parent
b8570b5c1c
commit
36d0a17dc4
1 changed files with 25 additions and 2 deletions
|
@ -607,21 +607,41 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
|
||||||
final TwoStateOwner cowner = new TwoStateOwner(this, "liveUnseenNotify");
|
final TwoStateOwner cowner = new TwoStateOwner(this, "liveUnseenNotify");
|
||||||
|
|
||||||
db.folder().liveSynchronizing().observe(this, new Observer<List<TupleFolderSync>>() {
|
db.folder().liveSynchronizing().observe(this, new Observer<List<TupleFolderSync>>() {
|
||||||
|
private List<Long> lastAccounts = new ArrayList<>();
|
||||||
|
private List<Long> lastFolders = new ArrayList<>();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChanged(List<TupleFolderSync> syncs) {
|
public void onChanged(List<TupleFolderSync> syncs) {
|
||||||
int syncing = 0;
|
int syncing = 0;
|
||||||
|
boolean changed = false;
|
||||||
List<Long> accounts = new ArrayList<>();
|
List<Long> accounts = new ArrayList<>();
|
||||||
List<Long> folders = new ArrayList<>();
|
List<Long> folders = new ArrayList<>();
|
||||||
if (syncs != null)
|
if (syncs != null)
|
||||||
for (TupleFolderSync sync : syncs) {
|
for (TupleFolderSync sync : syncs) {
|
||||||
if ("syncing".equals(sync.sync_state))
|
if ("syncing".equals(sync.sync_state))
|
||||||
syncing++;
|
syncing++;
|
||||||
if (sync.unified && !accounts.contains(sync.account))
|
|
||||||
|
if (sync.unified && !accounts.contains(sync.account)) {
|
||||||
accounts.add(sync.account);
|
accounts.add(sync.account);
|
||||||
|
if (lastAccounts.contains(sync.account))
|
||||||
|
lastAccounts.remove(sync.account); // same
|
||||||
|
else
|
||||||
|
changed = true; // new
|
||||||
|
}
|
||||||
|
|
||||||
folders.add(sync.folder);
|
folders.add(sync.folder);
|
||||||
|
if (lastFolders.contains(sync.folder))
|
||||||
|
lastFolders.remove(sync.folder); // same
|
||||||
|
else
|
||||||
|
changed = true; // new
|
||||||
}
|
}
|
||||||
|
|
||||||
Log.i("Syncing=" + syncing +
|
changed = (changed || lastAccounts.size() > 0 || lastFolders.size() > 0); // deleted
|
||||||
|
lastAccounts = accounts;
|
||||||
|
lastFolders = folders;
|
||||||
|
|
||||||
|
Log.i("Changed=" + changed +
|
||||||
|
" syncing=" + syncing +
|
||||||
" folders=" + folders.size() +
|
" folders=" + folders.size() +
|
||||||
" accounts=" + accounts.size());
|
" accounts=" + accounts.size());
|
||||||
|
|
||||||
|
@ -630,6 +650,9 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
|
||||||
else
|
else
|
||||||
cowner.stop();
|
cowner.stop();
|
||||||
|
|
||||||
|
if (!changed)
|
||||||
|
return;
|
||||||
|
|
||||||
for (String _key : prefs.getAll().keySet())
|
for (String _key : prefs.getAll().keySet())
|
||||||
if (_key.startsWith("widget.") && _key.endsWith(".refresh") &&
|
if (_key.startsWith("widget.") && _key.endsWith(".refresh") &&
|
||||||
prefs.getBoolean(_key, false)) {
|
prefs.getBoolean(_key, false)) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue