From f23535a19fdfe84b59ecefed5bb15cc386cd3734 Mon Sep 17 00:00:00 2001 From: M66B Date: Tue, 3 Nov 2020 09:58:25 +0100 Subject: [PATCH] Clear blank columns --- .../java/eu/faircode/email/HtmlHelper.java | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/app/src/main/java/eu/faircode/email/HtmlHelper.java b/app/src/main/java/eu/faircode/email/HtmlHelper.java index 0c2646071b..08084d0949 100644 --- a/app/src/main/java/eu/faircode/email/HtmlHelper.java +++ b/app/src/main/java/eu/faircode/email/HtmlHelper.java @@ -136,6 +136,8 @@ public class HtmlHelper { private static final int SMALL_IMAGE_SIZE = 5; // pixels private static final int TRACKING_PIXEL_SURFACE = 25; // pixels private static final float[] HEADING_SIZES = {1.5f, 1.4f, 1.3f, 1.2f, 1.1f, 1f}; + private static String WHITESPACE = " \t\f"; + private static String WHITESPACE_NL = WHITESPACE + "\r\n"; private static final String LINE = "----------------------------------------"; private static final HashMap x11ColorMap = new HashMap<>(); @@ -833,17 +835,19 @@ public class HtmlHelper { // Tables // https://developer.mozilla.org/en-US/docs/Web/HTML/Element/table for (Element col : document.select("th,td")) { - // Clear columns with non breaking spaces + // Clear blank columns if (col.childNodeSize() == 1 && col.childNode(0) instanceof TextNode) { - boolean nbsp = true; + boolean blank = true; String text = ((TextNode) col.childNode(0)).getWholeText(); - for (int i = 0; i < text.length(); i++) - if (text.charAt(i) != '\u00a0') { - nbsp = false; + for (int i = 0; i < text.length(); i++) { + char kar = text.charAt(i); + if (WHITESPACE.indexOf(kar) < 0 && kar != '\u00a0' /* nbsp */) { + blank = false; break; } - if (nbsp) + } + if (blank) col.html(""); } @@ -1938,8 +1942,6 @@ public class HtmlHelper { private int plain = 0; private List block = new ArrayList<>(); - private String WHITESPACE = " \t\f"; - private String WHITESPACE_NL = WHITESPACE + "\r\n"; private Pattern TRIM_WHITESPACE_NL = Pattern.compile("[" + WHITESPACE + "]*\\r?\\n[" + WHITESPACE + "]*");