mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-01 12:44:42 +00:00
Use tasks to get data to order
This commit is contained in:
parent
106f14b39c
commit
d232bc882c
2 changed files with 30 additions and 9 deletions
|
@ -56,7 +56,7 @@ public interface DaoFolder {
|
||||||
" FROM folder" +
|
" FROM folder" +
|
||||||
" JOIN account ON account.id = folder.account" +
|
" JOIN account ON account.id = folder.account" +
|
||||||
" WHERE account.`synchronize`")
|
" WHERE account.`synchronize`")
|
||||||
LiveData<List<TupleFolderSort>> liveSort();
|
List<TupleFolderSort> getSortedFolders();
|
||||||
|
|
||||||
@Query("SELECT folder.*" +
|
@Query("SELECT folder.*" +
|
||||||
", account.`order` AS accountOrder, account.name AS accountName, account.color AS accountColor, account.state AS accountState" +
|
", account.`order` AS accountOrder, account.name AS accountName, account.color AS accountColor, account.state AS accountState" +
|
||||||
|
|
|
@ -31,7 +31,6 @@ import android.view.ViewGroup;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.constraintlayout.widget.Group;
|
import androidx.constraintlayout.widget.Group;
|
||||||
import androidx.lifecycle.Observer;
|
|
||||||
import androidx.recyclerview.widget.ItemTouchHelper;
|
import androidx.recyclerview.widget.ItemTouchHelper;
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
import androidx.recyclerview.widget.LinearLayoutManager;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
@ -97,9 +96,15 @@ public class FragmentOrder extends FragmentBase {
|
||||||
DB db = DB.getInstance(getContext());
|
DB db = DB.getInstance(getContext());
|
||||||
|
|
||||||
if (EntityAccount.class.getName().equals(clazz))
|
if (EntityAccount.class.getName().equals(clazz))
|
||||||
db.account().liveSynchronizingAccounts().observe(getViewLifecycleOwner(), new Observer<List<EntityAccount>>() {
|
new SimpleTask<List<EntityAccount>>() {
|
||||||
@Override
|
@Override
|
||||||
public void onChanged(List<EntityAccount> accounts) {
|
protected List<EntityAccount> onExecute(Context context, Bundle args) {
|
||||||
|
DB db = DB.getInstance(context);
|
||||||
|
return db.account().getSynchronizingAccounts();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onExecuted(Bundle args, List<EntityAccount> accounts) {
|
||||||
if (accounts == null)
|
if (accounts == null)
|
||||||
accounts = new ArrayList<>();
|
accounts = new ArrayList<>();
|
||||||
|
|
||||||
|
@ -110,11 +115,22 @@ public class FragmentOrder extends FragmentBase {
|
||||||
pbWait.setVisibility(View.GONE);
|
pbWait.setVisibility(View.GONE);
|
||||||
grpReady.setVisibility(View.VISIBLE);
|
grpReady.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
});
|
|
||||||
else if (TupleFolderSort.class.getName().equals(clazz))
|
|
||||||
db.folder().liveSort().observe(getViewLifecycleOwner(), new Observer<List<TupleFolderSort>>() {
|
|
||||||
@Override
|
@Override
|
||||||
public void onChanged(List<TupleFolderSort> folders) {
|
protected void onException(Bundle args, Throwable ex) {
|
||||||
|
Helper.unexpectedError(getContext(), getViewLifecycleOwner(), ex);
|
||||||
|
}
|
||||||
|
}.execute(this, new Bundle(), "order:accounts");
|
||||||
|
else if (TupleFolderSort.class.getName().equals(clazz))
|
||||||
|
new SimpleTask<List<TupleFolderSort>>() {
|
||||||
|
@Override
|
||||||
|
protected List<TupleFolderSort> onExecute(Context context, Bundle args) {
|
||||||
|
DB db = DB.getInstance(context);
|
||||||
|
return db.folder().getSortedFolders();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onExecuted(Bundle args, List<TupleFolderSort> folders) {
|
||||||
if (folders == null)
|
if (folders == null)
|
||||||
folders = new ArrayList<>();
|
folders = new ArrayList<>();
|
||||||
|
|
||||||
|
@ -125,7 +141,12 @@ public class FragmentOrder extends FragmentBase {
|
||||||
pbWait.setVisibility(View.GONE);
|
pbWait.setVisibility(View.GONE);
|
||||||
grpReady.setVisibility(View.VISIBLE);
|
grpReady.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
@Override
|
||||||
|
protected void onException(Bundle args, Throwable ex) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}.execute(this, new Bundle(), "order:folders");
|
||||||
else
|
else
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue