|
|
@ -93,7 +93,7 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
// Get arguments
|
|
|
|
// Get arguments
|
|
|
|
Bundle args = getArguments();
|
|
|
|
Bundle args = getArguments();
|
|
|
|
String action = (args == null ? null : args.getString("action"));
|
|
|
|
String action = (args == null ? null : args.getString("action"));
|
|
|
|
final long id = (TextUtils.isEmpty(action) ? (args == null ? -1 : args.getLong("id" , -1)) : -1);
|
|
|
|
final long id = (TextUtils.isEmpty(action) ? (args == null ? -1 : args.getLong("id", -1)) : -1);
|
|
|
|
|
|
|
|
|
|
|
|
// Get controls
|
|
|
|
// Get controls
|
|
|
|
spFrom = view.findViewById(R.id.spFrom);
|
|
|
|
spFrom = view.findViewById(R.id.spFrom);
|
|
|
@ -117,7 +117,7 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void onClick(View view) {
|
|
|
|
public void onClick(View view) {
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
args.putLong("id" , -1);
|
|
|
|
args.putLong("id", -1);
|
|
|
|
|
|
|
|
|
|
|
|
FragmentIdentity fragment = new FragmentIdentity();
|
|
|
|
FragmentIdentity fragment = new FragmentIdentity();
|
|
|
|
fragment.setArguments(args);
|
|
|
|
fragment.setArguments(args);
|
|
|
@ -181,7 +181,12 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
pbWait.setVisibility(View.VISIBLE);
|
|
|
|
pbWait.setVisibility(View.VISIBLE);
|
|
|
|
bottom_navigation.getMenu().setGroupEnabled(0, false);
|
|
|
|
bottom_navigation.getMenu().setGroupEnabled(0, false);
|
|
|
|
|
|
|
|
|
|
|
|
final Handler handler = new Handler();
|
|
|
|
return view;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
|
|
|
|
|
|
|
|
super.onActivityCreated(savedInstanceState);
|
|
|
|
|
|
|
|
|
|
|
|
DB.getInstance(getContext()).identity().liveIdentities(true).observe(FragmentCompose.this, new Observer<List<EntityIdentity>>() {
|
|
|
|
DB.getInstance(getContext()).identity().liveIdentities(true).observe(FragmentCompose.this, new Observer<List<EntityIdentity>>() {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
@ -207,19 +212,10 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
spFrom.setVisibility(View.VISIBLE);
|
|
|
|
spFrom.setVisibility(View.VISIBLE);
|
|
|
|
ivIdentityAdd.setVisibility(View.VISIBLE);
|
|
|
|
ivIdentityAdd.setVisibility(View.VISIBLE);
|
|
|
|
|
|
|
|
|
|
|
|
// For some reason this is needed to make sure the loader starts
|
|
|
|
// Get might select another identity
|
|
|
|
handler.post(new Runnable() {
|
|
|
|
getLoaderManager().restartLoader(ActivityCompose.LOADER_COMPOSE_GET, getArguments(), getLoaderCallbacks).forceLoad();
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void run() {
|
|
|
|
|
|
|
|
// Get might select another identity
|
|
|
|
|
|
|
|
getLoaderManager().restartLoader(ActivityCompose.LOADER_COMPOSE_GET, getArguments(), getLoaderCallbacks).forceLoad();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return view;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
@ -298,16 +294,16 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
EntityIdentity identity = (EntityIdentity) spFrom.getSelectedItem();
|
|
|
|
EntityIdentity identity = (EntityIdentity) spFrom.getSelectedItem();
|
|
|
|
|
|
|
|
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
args.putLong("id" , id);
|
|
|
|
args.putLong("id", id);
|
|
|
|
args.putLong("iid" , identity == null ? -1 : identity.id);
|
|
|
|
args.putLong("iid", identity == null ? -1 : identity.id);
|
|
|
|
args.putString("thread" , FragmentCompose.this.thread);
|
|
|
|
args.putString("thread", FragmentCompose.this.thread);
|
|
|
|
args.putLong("rid" , FragmentCompose.this.rid);
|
|
|
|
args.putLong("rid", FragmentCompose.this.rid);
|
|
|
|
args.putString("to" , etTo.getText().toString());
|
|
|
|
args.putString("to", etTo.getText().toString());
|
|
|
|
args.putString("cc" , etCc.getText().toString());
|
|
|
|
args.putString("cc", etCc.getText().toString());
|
|
|
|
args.putString("bcc" , etBcc.getText().toString());
|
|
|
|
args.putString("bcc", etBcc.getText().toString());
|
|
|
|
args.putString("subject" , etSubject.getText().toString());
|
|
|
|
args.putString("subject", etSubject.getText().toString());
|
|
|
|
args.putString("body" , etBody.getText().toString());
|
|
|
|
args.putString("body", etBody.getText().toString());
|
|
|
|
args.putString("action" , action);
|
|
|
|
args.putString("action", action);
|
|
|
|
|
|
|
|
|
|
|
|
getLoaderManager().restartLoader(ActivityCompose.LOADER_COMPOSE_PUT, args, putLoaderCallbacks).forceLoad();
|
|
|
|
getLoaderManager().restartLoader(ActivityCompose.LOADER_COMPOSE_PUT, args, putLoaderCallbacks).forceLoad();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -329,35 +325,35 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
Bundle result = new Bundle();
|
|
|
|
Bundle result = new Bundle();
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
String action = args.getString("action");
|
|
|
|
String action = args.getString("action");
|
|
|
|
long id = args.getLong("id" , -1);
|
|
|
|
long id = args.getLong("id", -1);
|
|
|
|
EntityMessage msg = DB.getInstance(getContext()).message().getMessage(id);
|
|
|
|
EntityMessage msg = DB.getInstance(getContext()).message().getMessage(id);
|
|
|
|
|
|
|
|
|
|
|
|
result.putString("action" , action);
|
|
|
|
result.putString("action", action);
|
|
|
|
|
|
|
|
|
|
|
|
if (msg != null) {
|
|
|
|
if (msg != null) {
|
|
|
|
if (msg.identity != null)
|
|
|
|
if (msg.identity != null)
|
|
|
|
result.putLong("iid" , msg.identity);
|
|
|
|
result.putLong("iid", msg.identity);
|
|
|
|
if (msg.replying != null)
|
|
|
|
if (msg.replying != null)
|
|
|
|
result.putLong("rid" , msg.replying);
|
|
|
|
result.putLong("rid", msg.replying);
|
|
|
|
result.putSerializable("cc" , msg.cc);
|
|
|
|
result.putSerializable("cc", msg.cc);
|
|
|
|
result.putSerializable("bcc" , msg.bcc);
|
|
|
|
result.putSerializable("bcc", msg.bcc);
|
|
|
|
result.putString("thread" , msg.thread);
|
|
|
|
result.putString("thread", msg.thread);
|
|
|
|
result.putString("subject" , msg.subject);
|
|
|
|
result.putString("subject", msg.subject);
|
|
|
|
result.putString("body" , msg.body);
|
|
|
|
result.putString("body", msg.body);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(action)) {
|
|
|
|
if (TextUtils.isEmpty(action)) {
|
|
|
|
if (msg != null) {
|
|
|
|
if (msg != null) {
|
|
|
|
result.putSerializable("from" , msg.from);
|
|
|
|
result.putSerializable("from", msg.from);
|
|
|
|
result.putSerializable("to" , msg.to);
|
|
|
|
result.putSerializable("to", msg.to);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if ("reply".equals(action)) {
|
|
|
|
} else if ("reply".equals(action)) {
|
|
|
|
Address[] to = null;
|
|
|
|
Address[] to = null;
|
|
|
|
if (msg != null)
|
|
|
|
if (msg != null)
|
|
|
|
to = (msg.reply == null || msg.reply.length == 0 ? msg.from : msg.reply);
|
|
|
|
to = (msg.reply == null || msg.reply.length == 0 ? msg.from : msg.reply);
|
|
|
|
result.putLong("rid" , msg.id);
|
|
|
|
result.putLong("rid", msg.id);
|
|
|
|
result.putSerializable("from" , msg.to);
|
|
|
|
result.putSerializable("from", msg.to);
|
|
|
|
result.putSerializable("to" , to);
|
|
|
|
result.putSerializable("to", to);
|
|
|
|
} else if ("reply_all".equals(action)) {
|
|
|
|
} else if ("reply_all".equals(action)) {
|
|
|
|
Address[] to = null;
|
|
|
|
Address[] to = null;
|
|
|
|
if (msg != null) {
|
|
|
|
if (msg != null) {
|
|
|
@ -370,15 +366,15 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
addresses.addAll(Arrays.asList(msg.cc));
|
|
|
|
addresses.addAll(Arrays.asList(msg.cc));
|
|
|
|
to = addresses.toArray(new Address[0]);
|
|
|
|
to = addresses.toArray(new Address[0]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
result.putLong("rid" , msg.id);
|
|
|
|
result.putLong("rid", msg.id);
|
|
|
|
result.putSerializable("from" , msg.to);
|
|
|
|
result.putSerializable("from", msg.to);
|
|
|
|
result.putSerializable("to" , to);
|
|
|
|
result.putSerializable("to", to);
|
|
|
|
} else if ("forward".equals(action)) {
|
|
|
|
} else if ("forward".equals(action)) {
|
|
|
|
Address[] to = null;
|
|
|
|
Address[] to = null;
|
|
|
|
if (msg != null)
|
|
|
|
if (msg != null)
|
|
|
|
to = (msg.reply == null || msg.reply.length == 0 ? msg.from : msg.reply);
|
|
|
|
to = (msg.reply == null || msg.reply.length == 0 ? msg.from : msg.reply);
|
|
|
|
result.putSerializable("from" , msg.to);
|
|
|
|
result.putSerializable("from", msg.to);
|
|
|
|
result.putSerializable("to" , to);
|
|
|
|
result.putSerializable("to", to);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
Log.e(Helper.TAG, ex + "\n" + Log.getStackTraceString(ex));
|
|
|
|
Log.e(Helper.TAG, ex + "\n" + Log.getStackTraceString(ex));
|
|
|
@ -400,8 +396,8 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
public void onLoadFinished(@NonNull Loader<Bundle> loader, Bundle result) {
|
|
|
|
public void onLoadFinished(@NonNull Loader<Bundle> loader, Bundle result) {
|
|
|
|
getLoaderManager().destroyLoader(loader.getId());
|
|
|
|
getLoaderManager().destroyLoader(loader.getId());
|
|
|
|
|
|
|
|
|
|
|
|
long iid = result.getLong("iid" , -1);
|
|
|
|
long iid = result.getLong("iid", -1);
|
|
|
|
long rid = result.getLong("rid" , -1);
|
|
|
|
long rid = result.getLong("rid", -1);
|
|
|
|
String thread = result.getString("thread");
|
|
|
|
String thread = result.getString("thread");
|
|
|
|
Address[] from = (Address[]) result.getSerializable("from");
|
|
|
|
Address[] from = (Address[]) result.getSerializable("from");
|
|
|
|
Address[] to = (Address[]) result.getSerializable("to");
|
|
|
|
Address[] to = (Address[]) result.getSerializable("to");
|
|
|
@ -437,11 +433,11 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
|
|
|
|
|
|
|
|
Handler handler = new Handler();
|
|
|
|
Handler handler = new Handler();
|
|
|
|
|
|
|
|
|
|
|
|
etCc.setText(cc == null ? null : TextUtils.join(", " , cc));
|
|
|
|
etCc.setText(cc == null ? null : TextUtils.join(", ", cc));
|
|
|
|
etBcc.setText(bcc == null ? null : TextUtils.join(", " , bcc));
|
|
|
|
etBcc.setText(bcc == null ? null : TextUtils.join(", ", bcc));
|
|
|
|
|
|
|
|
|
|
|
|
if (action == null) {
|
|
|
|
if (action == null) {
|
|
|
|
etTo.setText(to == null ? null : TextUtils.join(", " , to));
|
|
|
|
etTo.setText(to == null ? null : TextUtils.join(", ", to));
|
|
|
|
etSubject.setText(subject);
|
|
|
|
etSubject.setText(subject);
|
|
|
|
if (body != null)
|
|
|
|
if (body != null)
|
|
|
|
etBody.setText(Html.fromHtml(HtmlHelper.sanitize(getContext(), body, false)));
|
|
|
|
etBody.setText(Html.fromHtml(HtmlHelper.sanitize(getContext(), body, false)));
|
|
|
@ -452,10 +448,10 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
} else if ("reply".equals(action) || "reply_all".equals(action)) {
|
|
|
|
} else if ("reply".equals(action) || "reply_all".equals(action)) {
|
|
|
|
etTo.setText(to == null ? null : TextUtils.join(", " , to));
|
|
|
|
etTo.setText(to == null ? null : TextUtils.join(", ", to));
|
|
|
|
String text = String.format("<br><br>%s %s:<br><br>%s" ,
|
|
|
|
String text = String.format("<br><br>%s %s:<br><br>%s",
|
|
|
|
Html.escapeHtml(new Date().toString()),
|
|
|
|
Html.escapeHtml(new Date().toString()),
|
|
|
|
Html.escapeHtml(to == null ? "" : TextUtils.join(", " , to)),
|
|
|
|
Html.escapeHtml(to == null ? "" : TextUtils.join(", ", to)),
|
|
|
|
HtmlHelper.sanitize(getContext(), body, true));
|
|
|
|
HtmlHelper.sanitize(getContext(), body, true));
|
|
|
|
etSubject.setText(getContext().getString(R.string.title_subject_reply, subject));
|
|
|
|
etSubject.setText(getContext().getString(R.string.title_subject_reply, subject));
|
|
|
|
etBody.setText(Html.fromHtml(text));
|
|
|
|
etBody.setText(Html.fromHtml(text));
|
|
|
@ -466,9 +462,9 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
} else if ("forward".equals(action)) {
|
|
|
|
} else if ("forward".equals(action)) {
|
|
|
|
String text = String.format("<br><br>%s %s:<br><br>%s" ,
|
|
|
|
String text = String.format("<br><br>%s %s:<br><br>%s",
|
|
|
|
Html.escapeHtml(new Date().toString()),
|
|
|
|
Html.escapeHtml(new Date().toString()),
|
|
|
|
Html.escapeHtml(to == null ? "" : TextUtils.join(", " , to)),
|
|
|
|
Html.escapeHtml(to == null ? "" : TextUtils.join(", ", to)),
|
|
|
|
HtmlHelper.sanitize(getContext(), body, true));
|
|
|
|
HtmlHelper.sanitize(getContext(), body, true));
|
|
|
|
etSubject.setText(getContext().getString(R.string.title_subject_forward, subject));
|
|
|
|
etSubject.setText(getContext().getString(R.string.title_subject_forward, subject));
|
|
|
|
etBody.setText(Html.fromHtml(text));
|
|
|
|
etBody.setText(Html.fromHtml(text));
|
|
|
@ -519,7 +515,7 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
if (drafts == null)
|
|
|
|
if (drafts == null)
|
|
|
|
throw new Throwable(getContext().getString(R.string.title_no_primary_drafts));
|
|
|
|
throw new Throwable(getContext().getString(R.string.title_no_primary_drafts));
|
|
|
|
|
|
|
|
|
|
|
|
long rid = args.getLong("rid" , -1);
|
|
|
|
long rid = args.getLong("rid", -1);
|
|
|
|
String thread = args.getString("thread");
|
|
|
|
String thread = args.getString("thread");
|
|
|
|
String to = args.getString("to");
|
|
|
|
String to = args.getString("to");
|
|
|
|
String cc = args.getString("cc");
|
|
|
|
String cc = args.getString("cc");
|
|
|
@ -546,7 +542,7 @@ public class FragmentCompose extends FragmentEx {
|
|
|
|
draft.cc = acc;
|
|
|
|
draft.cc = acc;
|
|
|
|
draft.bcc = abcc;
|
|
|
|
draft.bcc = abcc;
|
|
|
|
draft.subject = subject;
|
|
|
|
draft.subject = subject;
|
|
|
|
draft.body = "<pre>" + body.replaceAll("\\r?\\n" , "<br />") + "</pre>";
|
|
|
|
draft.body = "<pre>" + body.replaceAll("\\r?\\n", "<br />") + "</pre>";
|
|
|
|
draft.received = new Date().getTime();
|
|
|
|
draft.received = new Date().getTime();
|
|
|
|
draft.seen = false;
|
|
|
|
draft.seen = false;
|
|
|
|
draft.ui_seen = false;
|
|
|
|
draft.ui_seen = false;
|
|
|
|