|
|
@ -5512,6 +5512,37 @@ public class FragmentCompose extends FragmentBase {
|
|
|
|
if (TextUtils.isEmpty(extra))
|
|
|
|
if (TextUtils.isEmpty(extra))
|
|
|
|
extra = null;
|
|
|
|
extra = null;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (action == R.id.action_send) {
|
|
|
|
|
|
|
|
if (draft.plain_only == null || !draft.plain_only) {
|
|
|
|
|
|
|
|
// Remove unused inline images
|
|
|
|
|
|
|
|
List<String> cids = new ArrayList<>();
|
|
|
|
|
|
|
|
Document d = JsoupEx.parse(body);
|
|
|
|
|
|
|
|
for (Element element : d.select("img")) {
|
|
|
|
|
|
|
|
String src = element.attr("src");
|
|
|
|
|
|
|
|
if (src.startsWith("cid:"))
|
|
|
|
|
|
|
|
cids.add("<" + src.substring(4) + ">");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (EntityAttachment attachment : new ArrayList<>(attachments))
|
|
|
|
|
|
|
|
if (attachment.isInline() && attachment.isImage() &&
|
|
|
|
|
|
|
|
attachment.cid != null && !cids.contains(attachment.cid)) {
|
|
|
|
|
|
|
|
Log.i("Removing unused inline attachment cid=" + attachment.cid);
|
|
|
|
|
|
|
|
attachments.remove(attachment);
|
|
|
|
|
|
|
|
db.attachment().deleteAttachment(attachment.id);
|
|
|
|
|
|
|
|
dirty = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
// Convert inline images to attachments
|
|
|
|
|
|
|
|
for (EntityAttachment attachment : new ArrayList<>(attachments))
|
|
|
|
|
|
|
|
if (attachment.isInline() && attachment.isImage()) {
|
|
|
|
|
|
|
|
Log.i("Converting to attachment cid=" + attachment.cid);
|
|
|
|
|
|
|
|
attachment.disposition = Part.ATTACHMENT;
|
|
|
|
|
|
|
|
db.attachment().setDisposition(attachment.id, attachment.disposition);
|
|
|
|
|
|
|
|
dirty = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int available = 0;
|
|
|
|
int available = 0;
|
|
|
|
List<Integer> eparts = new ArrayList<>();
|
|
|
|
List<Integer> eparts = new ArrayList<>();
|
|
|
|
for (EntityAttachment attachment : attachments)
|
|
|
|
for (EntityAttachment attachment : attachments)
|
|
|
@ -5916,32 +5947,6 @@ public class FragmentCompose extends FragmentBase {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} else if (action == R.id.action_send) {
|
|
|
|
} else if (action == R.id.action_send) {
|
|
|
|
if (draft.plain_only == null || !draft.plain_only) {
|
|
|
|
|
|
|
|
// Remove unused inline images
|
|
|
|
|
|
|
|
List<String> cids = new ArrayList<>();
|
|
|
|
|
|
|
|
Document d = JsoupEx.parse(body);
|
|
|
|
|
|
|
|
for (Element element : d.select("img")) {
|
|
|
|
|
|
|
|
String src = element.attr("src");
|
|
|
|
|
|
|
|
if (src.startsWith("cid:"))
|
|
|
|
|
|
|
|
cids.add("<" + src.substring(4) + ">");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (EntityAttachment attachment : new ArrayList<>(attachments))
|
|
|
|
|
|
|
|
if (attachment.isInline() && attachment.isImage() &&
|
|
|
|
|
|
|
|
attachment.cid != null && !cids.contains(attachment.cid)) {
|
|
|
|
|
|
|
|
Log.i("Removing unused inline attachment cid=" + attachment.cid);
|
|
|
|
|
|
|
|
db.attachment().deleteAttachment(attachment.id);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
// Convert inline images to attachments
|
|
|
|
|
|
|
|
for (EntityAttachment attachment : new ArrayList<>(attachments))
|
|
|
|
|
|
|
|
if (attachment.isInline() && attachment.isImage()) {
|
|
|
|
|
|
|
|
Log.i("Converting to attachment cid=" + attachment.cid);
|
|
|
|
|
|
|
|
attachment.disposition = Part.ATTACHMENT;
|
|
|
|
|
|
|
|
db.attachment().setDisposition(attachment.id, attachment.disposition);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Delete draft (cannot move to outbox)
|
|
|
|
// Delete draft (cannot move to outbox)
|
|
|
|
EntityOperation.queue(context, draft, EntityOperation.DELETE);
|
|
|
|
EntityOperation.queue(context, draft, EntityOperation.DELETE);
|
|
|
|
|
|
|
|
|
|
|
|