Implementation
StyledElement parseStyledElement(
dom.Element element,
List<StyledElement> children,
) {
StyledElement styledElement = StyledElement(
name: element.localName!,
elementId: element.id,
elementClasses: element.classes.toList(),
children: children,
node: element,
style: Style(),
);
switch (element.localName) {
case "abbr":
case "acronym":
styledElement.style = Style(
textDecoration: TextDecoration.underline,
textDecorationStyle: TextDecorationStyle.dotted,
);
break;
case "address":
continue italics;
case "article":
styledElement.style = Style(
display: Display.block,
);
break;
case "aside":
styledElement.style = Style(
display: Display.block,
);
break;
bold:
case "b":
styledElement.style = Style(
fontWeight: FontWeight.bold,
);
break;
case "bdo":
TextDirection textDirection =
((element.attributes["dir"] ?? "ltr") == "rtl")
? TextDirection.rtl
: TextDirection.ltr;
styledElement.style = Style(
direction: textDirection,
);
break;
case "big":
styledElement.style = Style(
fontSize: FontSize.larger,
);
break;
case "blockquote":
//TODO(Sub6Resources) this is a workaround for collapsing margins. Remove.
if (element.parent!.localName == "blockquote") {
styledElement.style = Style(
margin: Margins.only(left: 40.0, right: 40.0, bottom: 14.0),
display: Display.block,
);
} else {
styledElement.style = Style(
margin: Margins.symmetric(horizontal: 40.0, vertical: 14.0),
display: Display.block,
);
}
break;
case "body":
styledElement.style = Style(
margin: Margins.all(8.0),
display: Display.block,
);
break;
case "center":
styledElement.style = Style(
alignment: Alignment.center,
display: Display.block,
);
break;
case "cite":
continue italics;
monospace:
case "code":
styledElement.style = Style(
fontFamily: 'Monospace',
);
break;
case "dd":
styledElement.style = Style(
margin: Margins.only(left: 40.0),
display: Display.block,
);
break;
strikeThrough:
case "del":
styledElement.style = Style(
textDecoration: TextDecoration.lineThrough,
);
break;
case "dfn":
continue italics;
case "div":
styledElement.style = Style(
margin: Margins.all(0),
display: Display.block,
);
break;
case "dl":
styledElement.style = Style(
margin: Margins.symmetric(vertical: 14.0),
display: Display.block,
);
break;
case "dt":
styledElement.style = Style(
display: Display.block,
);
break;
case "em":
continue italics;
case "figcaption":
styledElement.style = Style(
display: Display.block,
);
break;
case "figure":
styledElement.style = Style(
margin: Margins.symmetric(vertical: 14.0, horizontal: 40.0),
display: Display.block,
);
break;
case "footer":
styledElement.style = Style(
display: Display.block,
);
break;
case "font":
styledElement.style = Style(
color: element.attributes['color'] != null
? element.attributes['color']!.startsWith("#")
? ExpressionMapping.stringToColor(element.attributes['color']!)
: ExpressionMapping.namedColorToColor(
element.attributes['color']!)
: null,
fontFamily: element.attributes['face']?.split(",").first,
fontSize: element.attributes['size'] != null
? numberToFontSize(element.attributes['size']!)
: null,
);
break;
case "h1":
styledElement.style = Style(
fontSize: FontSize(2, Unit.em),
fontWeight: FontWeight.bold,
margin: Margins.symmetric(vertical: 0.67, unit: Unit.em),
display: Display.block,
);
break;
case "h2":
styledElement.style = Style(
fontSize: FontSize(1.5, Unit.em),
fontWeight: FontWeight.bold,
margin: Margins.symmetric(vertical: 0.83, unit: Unit.em),
display: Display.block,
);
break;
case "h3":
styledElement.style = Style(
fontSize: FontSize(1.17, Unit.em),
fontWeight: FontWeight.bold,
margin: Margins.symmetric(vertical: 1, unit: Unit.em),
display: Display.block,
);
break;
case "h4":
styledElement.style = Style(
fontWeight: FontWeight.bold,
margin: Margins.symmetric(vertical: 1.33, unit: Unit.em),
display: Display.block,
);
break;
case "h5":
styledElement.style = Style(
fontSize: FontSize(0.83, Unit.em),
fontWeight: FontWeight.bold,
margin: Margins.symmetric(vertical: 1.67, unit: Unit.em),
display: Display.block,
);
break;
case "h6":
styledElement.style = Style(
fontSize: FontSize(0.67, Unit.em),
fontWeight: FontWeight.bold,
margin: Margins.symmetric(vertical: 2.33, unit: Unit.em),
display: Display.block,
);
break;
case "header":
styledElement.style = Style(
display: Display.block,
);
break;
case "hr":
styledElement.style = Style(
margin: Margins(
top: Margin(0.5, Unit.em),
bottom: Margin(0.5, Unit.em),
left: Margin.auto(),
right: Margin.auto(),
),
border: Border.all(),
display: Display.block,
);
break;
case "html":
styledElement.style = Style(
display: Display.block,
);
break;
italics:
case "i":
styledElement.style = Style(
fontStyle: FontStyle.italic,
);
break;
case "ins":
continue underline;
case "kbd":
continue monospace;
case "li":
styledElement.style = Style(
display: Display.listItem,
);
break;
case "main":
styledElement.style = Style(
display: Display.block,
);
break;
case "mark":
styledElement.style = Style(
color: Colors.black,
backgroundColor: Colors.yellow,
);
break;
case "nav":
styledElement.style = Style(
display: Display.block,
);
break;
case "noscript":
styledElement.style = Style(
display: Display.block,
);
break;
case "ol":
case "ul":
styledElement.style = Style(
display: Display.block,
listStyleType: element.localName == "ol"
? ListStyleType.decimal
: ListStyleType.disc,
padding: const EdgeInsets.only(left: 40),
);
break;
case "p":
styledElement.style = Style(
margin: Margins.symmetric(vertical: 1, unit: Unit.em),
display: Display.block,
);
break;
case "pre":
styledElement.style = Style(
fontFamily: 'monospace',
margin: Margins.symmetric(vertical: 14.0),
whiteSpace: WhiteSpace.pre,
display: Display.block,
);
break;
case "q":
styledElement.style = Style(
before: "\"",
after: "\"",
);
break;
case "s":
continue strikeThrough;
case "samp":
continue monospace;
case "section":
styledElement.style = Style(
display: Display.block,
);
break;
case "small":
styledElement.style = Style(
fontSize: FontSize.smaller,
);
break;
case "strike":
continue strikeThrough;
case "strong":
continue bold;
case "sub":
styledElement.style = Style(
fontSize: FontSize.smaller,
verticalAlign: VerticalAlign.sub,
);
break;
case "sup":
styledElement.style = Style(
fontSize: FontSize.smaller,
verticalAlign: VerticalAlign.sup,
);
break;
case "tt":
continue monospace;
underline:
case "u":
styledElement.style = Style(
textDecoration: TextDecoration.underline,
);
break;
case "var":
continue italics;
}
return styledElement;
}