void
main() {
import
'package:flutter/material.dart'
;
import
'package:flutter_html/flutter_html.dart'
;
void
main() => runApp(
new
MyApp());
class
MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return
new
MaterialApp(
debugShowCheckedModeBanner:
false
,
title:
'Flutter Tutorial'
,
theme:
new
ThemeData(
primarySwatch: Colors.green,
),
home: MyHomePage(),
);
}
}
class
MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() =>
new
_MyHomePageState();
}
const
htmlData = r
""
"
<body style=
"background-color:powderblue;"
>
<h3>Support
for
math equations:</h3>
Solve
for
<var>x<sub>n</sub></var>:
log
<sub>2</sub>(<var>x</var><sup>2</sup>+<var>n</var>) = 9<sup>3</sup>
<h3>Inline Styles:</h3>
<p>This should be <span style=
'color: blue;'
>BLUE style=
'color: blue;'
</span></p>
<h3>Table support (with custom styling!):</h3>
<table>
<colgroup>
<col width=
"50%"
/>
<col span=
"2"
width=
"25%"
/>
</colgroup>
<thead>
<tr><th>One</th><th>Two</th><th>Three</th></tr>
</thead>
<tbody>
<tr>
<td rowspan=
'2'
>Rowspan</td><td>Data</td><td>Data</td>
</tr>
<tr>
</tr>
</tbody>
<tfoot>
<tr><td>fData</td><td>fData</td><td>fData</td></tr>
</tfoot>
</table>
<h4>Below is the custom tag: Flutter tag</h4>
<flutter vertical></flutter>
<h3>List support:</h3>
<ol>
<li>This</li>
<li>
<p>is</p>
</li>
<li>
ordered
<ul>
<li>This is a</li>
<li>nested</li>
<li>unordered list
</li>
</ul>
</li>
</ol>
<h3>Images are also supported:</h3>
<h3>Network png</h3>
<h3>Network svg</h3>
<h3>Data uri (with base64 support)</h3>
<img alt=
'Red dot (png)'
src=
''
/>
<img alt=
'Green dot (base64 svg)'
src=
''
/>
<img alt=
'Green dot (plain svg)'
src=
'data:image/svg+xml,%3C?xml version="1.0" encoding="UTF-8"?%3E%3Csvg viewBox="0 0 30 20" xmlns="http://www.w3.org/2000/svg"%3E%3Ccircle cx="15" cy="10" r="10" fill="yellow"/%3E%3C/svg%3E'
/>
""
";
class
_MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return
new
Scaffold(
appBar: AppBar(
title: Text(
'GeeksForGeeks'
),
centerTitle:
true
,
),
body: SingleChildScrollView(
child: Html(
data: htmlData,
tagsList: Html.tags..add(
"flutter"
),
style: {
"table"
: Style(
backgroundColor: Color.fromARGB(0x50, 0xee, 0xee, 0xee),
),
"tr"
: Style(
border: Border(bottom: BorderSide(color: Colors.grey)),
),
"th"
: Style(
padding: EdgeInsets.all(6),
backgroundColor: Colors.grey,
),
"td"
: Style(
padding: EdgeInsets.all(6),
alignment: Alignment.topLeft,
),
'h5'
: Style(maxLines: 2, textOverflow: TextOverflow.ellipsis),
},
customRender: {
"table"
: (context, child) {
return
SingleChildScrollView(
scrollDirection: Axis.horizontal,
child: (context.tree as TableLayoutElement).toWidget(context),
);
},
"flutter"
: (RenderContext context, Widget child) {
return
FlutterLogo(
style: (context.tree.element!.attributes[
'horizontal'
] != null)
? FlutterLogoStyle.horizontal
: FlutterLogoStyle.markOnly,
textColor: context.style.color!,
size: context.style.fontSize!.size! * 5,
);
},
},
customImageRenders: {
networkSourceMatcher(domains: [
"flutter.dev"
]):
(context, attributes, element) {
return
FlutterLogo(size: 36);
},
networkSourceMatcher(domains: [
"mydomain.com"
]): networkImageRender(
headers: {
"Custom-Header"
:
"some-value"
},
altWidget: (alt) => Text(alt ??
""
),
loadingWidget: () => Text(
"Loading..."
),
),
(attr, _) =>
attr[
"src"
] != null && attr[
"src"
]!.startsWith(
"/wiki"
):
networkImageRender(
networkSourceMatcher():
networkImageRender(altWidget: (_) => FlutterLogo()),
},
onCssParseError: (css, messages) {
print(
"css that errored: $css"
);
print(
"error messages:"
);
messages.forEach((element) {
print(element);
});
},
),
),
);
}
}