Plain text: always attach images

pull/178/head
M66B 5 years ago
parent c009f1c4bf
commit 50bea656ea

@ -87,6 +87,11 @@ public interface DaoAttachment {
" WHERE id = :id") " WHERE id = :id")
void setError(long id, String error); void setError(long id, String error);
@Query("UPDATE attachment" +
" SET disposition = :disposition" +
" WHERE id = :id")
void setDisposition(long id, String disposition);
@Query("UPDATE attachment" + @Query("UPDATE attachment" +
" SET cid = :cid" + " SET cid = :cid" +
" WHERE id = :id") " WHERE id = :id")

@ -4098,20 +4098,30 @@ public class FragmentCompose extends FragmentBase {
} }
} else if (action == R.id.action_send) { } else if (action == R.id.action_send) {
// Remove unused inline images if (draft.plain_only == null || !draft.plain_only) {
List<String> cids = new ArrayList<>(); // Remove unused inline images
if (draft.plain_only == null || !draft.plain_only) List<String> cids = new ArrayList<>();
for (Element element : JsoupEx.parse(body).select("img")) { Document d = JsoupEx.parse(body);
for (Element element : d.select("img")) {
String src = element.attr("src"); String src = element.attr("src");
if (src.startsWith("cid:")) if (src.startsWith("cid:"))
cids.add("<" + src.substring(4) + ">"); cids.add("<" + src.substring(4) + ">");
} }
for (EntityAttachment attachment : new ArrayList<>(attachments)) for (EntityAttachment attachment : new ArrayList<>(attachments))
if (attachment.isInline() && !cids.contains(attachment.cid)) { if (attachment.isInline() && !cids.contains(attachment.cid)) {
Log.i("Removing unused inline attachment cid=" + attachment.cid); Log.i("Removing unused inline attachment cid=" + attachment.cid);
db.attachment().deleteAttachment(attachment.id); db.attachment().deleteAttachment(attachment.id);
} }
} else {
// Convert inline images to attachments
for (EntityAttachment attachment : new ArrayList<>(attachments))
if (attachment.isInline()) {
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);

Loading…
Cancel
Save