mirror of
https://github.com/M66B/FairEmail.git
synced 2025-02-24 23:12:55 +00:00
Confirm single move, refactoring
This commit is contained in:
parent
e439d38ca6
commit
5a4b68e4f3
1 changed files with 31 additions and 24 deletions
|
@ -1595,13 +1595,14 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
|
||||||
try {
|
try {
|
||||||
db.beginTransaction();
|
db.beginTransaction();
|
||||||
|
|
||||||
EntityFolder target = db.folder().getFolder(tid);
|
|
||||||
if (target == null)
|
|
||||||
throw new IllegalArgumentException(context.getString(R.string.title_no_folder));
|
|
||||||
|
|
||||||
EntityAccount account = db.account().getAccount(target.account);
|
|
||||||
EntityMessage message = db.message().getMessage(id);
|
EntityMessage message = db.message().getMessage(id);
|
||||||
if (message != null) {
|
|
||||||
|
EntityFolder target = null;
|
||||||
|
if (message != null)
|
||||||
|
target = db.folder().getFolder(tid);
|
||||||
|
|
||||||
|
if (target != null) {
|
||||||
|
EntityAccount account = db.account().getAccount(target.account);
|
||||||
List<EntityMessage> messages = db.message().getMessagesByThread(
|
List<EntityMessage> messages = db.message().getMessagesByThread(
|
||||||
message.account, message.thread, threading && thread ? null : id, message.folder);
|
message.account, message.thread, threading && thread ? null : id, message.folder);
|
||||||
for (EntityMessage threaded : messages) {
|
for (EntityMessage threaded : messages) {
|
||||||
|
@ -4335,36 +4336,37 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onMove(Bundle args) {
|
private void onMove(Bundle args) {
|
||||||
new SimpleTask<Void>() {
|
new SimpleTask<ArrayList<MessageTarget>>() {
|
||||||
@Override
|
@Override
|
||||||
protected Void onExecute(Context context, Bundle args) {
|
protected ArrayList<MessageTarget> onExecute(Context context, Bundle args) {
|
||||||
long id = args.getLong("message");
|
long id = args.getLong("message");
|
||||||
long target = args.getLong("folder");
|
long tid = args.getLong("folder");
|
||||||
boolean copy = args.getBoolean("copy");
|
boolean copy = args.getBoolean("copy");
|
||||||
boolean similar = args.getBoolean("similar");
|
boolean similar = args.getBoolean("similar");
|
||||||
|
|
||||||
|
ArrayList<MessageTarget> result = new ArrayList<>();
|
||||||
|
|
||||||
DB db = DB.getInstance(context);
|
DB db = DB.getInstance(context);
|
||||||
try {
|
try {
|
||||||
db.beginTransaction();
|
db.beginTransaction();
|
||||||
|
|
||||||
EntityMessage message = db.message().getMessage(id);
|
EntityMessage message = db.message().getMessage(id);
|
||||||
if (message == null)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
if (similar) {
|
EntityFolder target = null;
|
||||||
if (copy)
|
if (message != null)
|
||||||
throw new IllegalArgumentException();
|
target = db.folder().getFolder(tid);
|
||||||
else {
|
|
||||||
|
if (target != null) {
|
||||||
|
EntityAccount account = db.account().getAccount(target.account);
|
||||||
|
if (account != null) {
|
||||||
List<EntityMessage> messages = db.message().getMessagesByThread(
|
List<EntityMessage> messages = db.message().getMessagesByThread(
|
||||||
message.account, message.thread, threading ? null : id, message.folder);
|
message.account, message.thread, threading && similar ? null : id, message.folder);
|
||||||
for (EntityMessage threaded : messages)
|
for (EntityMessage threaded : messages)
|
||||||
EntityOperation.queue(context, threaded, EntityOperation.MOVE, target);
|
if (copy)
|
||||||
|
EntityOperation.queue(context, message, EntityOperation.COPY, tid);
|
||||||
|
else
|
||||||
|
result.add(new MessageTarget(threaded, account, target));
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if (copy)
|
|
||||||
EntityOperation.queue(context, message, EntityOperation.COPY, target);
|
|
||||||
else
|
|
||||||
EntityOperation.queue(context, message, EntityOperation.MOVE, target);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
db.setTransactionSuccessful();
|
db.setTransactionSuccessful();
|
||||||
|
@ -4372,14 +4374,19 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
|
||||||
db.endTransaction();
|
db.endTransaction();
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onExecuted(Bundle args, ArrayList<MessageTarget> result) {
|
||||||
|
moveAsk(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onException(Bundle args, Throwable ex) {
|
protected void onException(Bundle args, Throwable ex) {
|
||||||
Helper.unexpectedError(getFragmentManager(), ex);
|
Helper.unexpectedError(getFragmentManager(), ex);
|
||||||
}
|
}
|
||||||
}.execute(this, args, "message:copy");
|
}.execute(this, args, "message:move");
|
||||||
}
|
}
|
||||||
|
|
||||||
private WebView printWebView = null;
|
private WebView printWebView = null;
|
||||||
|
|
Loading…
Reference in a new issue