From 91a78116e8c4c72028cf5dd3a9a582a798550e6a Mon Sep 17 00:00:00 2001 From: M66B Date: Tue, 18 Jan 2022 09:22:21 +0100 Subject: [PATCH] Guess schemes / relative links for images --- .../java/eu/faircode/email/HtmlHelper.java | 32 +++++++++---------- 1 file changed, 15 insertions(+), 17 deletions(-) diff --git a/app/src/main/java/eu/faircode/email/HtmlHelper.java b/app/src/main/java/eu/faircode/email/HtmlHelper.java index 80f8be8c23..38cf0e46ec 100644 --- a/app/src/main/java/eu/faircode/email/HtmlHelper.java +++ b/app/src/main/java/eu/faircode/email/HtmlHelper.java @@ -1301,26 +1301,23 @@ public class HtmlHelper { // https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base Elements b = document.select("base"); String base = (b.size() > 0 ? b.get(0).attr("href") : null); - for (Element a : document.select("a")) { - String href = a.attr("href"); - - if (href.contains(" ")) { - href = href.replace(" ", "%20"); - a.attr("href", href); - } + for (Element e : document.select("a,img")) { + String attr = ("a".equals(e.tagName()) ? "href" : "src"); + String link = e.attr(attr); if (!TextUtils.isEmpty(base)) try { // https://developer.android.com/reference/java/net/URI - href = URI.create(base).resolve(href).toString(); - a.attr("href", href); + link = URI.create(base).resolve(link.replace(" ", "%20")).toString(); + e.attr(attr, link); } catch (Throwable ex) { Log.w(ex); } - if (href.trim().startsWith("#")) { - a.tagName("span"); - a.removeAttr("href"); + if ("a".equals(e.tagName()) && + link.trim().startsWith("#")) { + e.tagName("span"); + e.removeAttr(attr); } } } @@ -1422,13 +1419,14 @@ public class HtmlHelper { } static void guessSchemes(Document document) { - for (Element a : document.select("a")) + for (Element e : document.select("a,img")) try { - String href = a.attr("href"); - if (TextUtils.isEmpty(href)) + String attr = ("a".equals(e.tagName()) ? "href" : "src"); + String url = e.attr(attr); + if (TextUtils.isEmpty(url)) continue; - Uri uri = UriHelper.guessScheme(Uri.parse(href)); - a.attr("href", uri.toString()); + Uri uri = UriHelper.guessScheme(Uri.parse(url)); + e.attr(attr, uri.toString()); } catch (Throwable ex) { Log.e(ex); }