Skip aligning table content

pull/178/head
M66B 5 years ago
parent 4117f533ea
commit eed8d3fb34

@ -519,13 +519,15 @@ public class HtmlHelper {
if ("center".equals(element.tagName())) { if ("center".equals(element.tagName())) {
style = mergeStyles(style, "text-align:center"); style = mergeStyles(style, "text-align:center");
element.tagName("div"); element.tagName("div");
} } else if ("table".equals(element.tagName()))
style = mergeStyles(style, "text-align:left");
else {
// https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes // https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes
String align = element.attr("align"); String align = element.attr("align");
if (!TextUtils.isEmpty(align)) if (!TextUtils.isEmpty(align))
style = mergeStyles(style, "text-align:" + align); style = mergeStyles(style, "text-align:" + align);
} }
}
// Process style // Process style
if (!TextUtils.isEmpty(style)) { if (!TextUtils.isEmpty(style)) {
@ -1910,14 +1912,21 @@ public class HtmlHelper {
ssb.setSpan(new StrikethroughSpan(), start, ssb.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); ssb.setSpan(new StrikethroughSpan(), start, ssb.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
break; break;
case "text-align": case "text-align":
for (AlignmentSpan span : ssb.getSpans(0, start, AlignmentSpan.class)) { boolean table = false;
int s = ssb.getSpanStart(span); Element e = element;
ssb.removeSpan(span); while (e != null) {
ssb.setSpan(span, s, start, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); if ("table".equals(e.tagName())) {
table = true;
break;
}
e = e.parent();
} }
if (!table) {
Layout.Alignment alignment = null; Layout.Alignment alignment = null;
switch (value) { switch (value) {
case "left": case "left":
case "justify":
alignment = (ltr ? Layout.Alignment.ALIGN_NORMAL : Layout.Alignment.ALIGN_OPPOSITE); alignment = (ltr ? Layout.Alignment.ALIGN_NORMAL : Layout.Alignment.ALIGN_OPPOSITE);
break; break;
case "center": case "center":
@ -1929,6 +1938,7 @@ public class HtmlHelper {
} }
if (alignment != null) if (alignment != null)
ssb.setSpan(new AlignmentSpan.Standard(alignment), start, ssb.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); ssb.setSpan(new AlignmentSpan.Standard(alignment), start, ssb.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
}
break; break;
} }
} }

Loading…
Cancel
Save