Skip to content

Commit

Permalink
content: Implement h1-h5
Browse files Browse the repository at this point in the history
Fixes: zulip#192
  • Loading branch information
sirpengi authored and gnprice committed Jan 31, 2024
1 parent bdac26f commit d413ffd
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 13 deletions.
5 changes: 2 additions & 3 deletions lib/model/content.dart
Original file line number Diff line number Diff line change
Expand Up @@ -927,11 +927,10 @@ class _ZulipContentParser {
case 'h5': headingLevel = HeadingLevel.h5; break;
case 'h6': headingLevel = HeadingLevel.h6; break;
}
if (headingLevel == HeadingLevel.h6 && classes.isEmpty) {
// TODO(#192) handle h1, h2, h3, h4, h5
if (headingLevel != null && classes.isEmpty) {
final parsed = parseBlockInline(element.nodes);
return HeadingNode(debugHtmlNode: debugHtmlNode,
level: headingLevel!,
level: headingLevel,
links: parsed.links,
nodes: parsed.nodes);
}
Expand Down
16 changes: 13 additions & 3 deletions lib/widgets/content.dart
Original file line number Diff line number Diff line change
Expand Up @@ -136,12 +136,22 @@ class Heading extends StatelessWidget {

@override
Widget build(BuildContext context) {
// TODO(#192) h1, h2, h3, h4, h5 -- same as h6 except font size
assert(node.level == HeadingLevel.h6);
// Em-heights taken from zulip:web/styles/rendered_markdown.css .
final emHeight = switch(node.level) {
HeadingLevel.h1 => 1.4,
HeadingLevel.h2 => 1.3,
HeadingLevel.h3 => 1.2,
HeadingLevel.h4 => 1.1,
HeadingLevel.h5 => 1.05,
HeadingLevel.h6 => 1.0,
};
return Padding(
padding: const EdgeInsets.only(top: 15, bottom: 5),
child: _buildBlockInlineContainer(
style: const TextStyle(fontWeight: FontWeight.w600, height: 1.4),
style: TextStyle(
fontSize: kBaseFontSize * emHeight,
fontWeight: FontWeight.w600,
height: 1.4),
node: node));
}
}
Expand Down
14 changes: 7 additions & 7 deletions test/model/content_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -219,14 +219,14 @@ void main() {
ParagraphNode(links: null, nodes: [TextNode('text')]),
]);

testParse('h1, h2, h3, h4, h5 unimplemented',
testParse('h1, h2, h3, h4, h5',
// "# one\n## two\n### three\n#### four\n##### five"
'<h1>one</h1>\n<h2>two</h2>\n<h3>three</h3>\n<h4>four</h4>\n<h5>five</h5>', [
blockUnimplemented('<h1>one</h1>'),
blockUnimplemented('<h2>two</h2>'),
blockUnimplemented('<h3>three</h3>'),
blockUnimplemented('<h4>four</h4>'),
blockUnimplemented('<h5>five</h5>'),
'<h1>one</h1>\n<h2>two</h2>\n<h3>three</h3>\n<h4>four</h4>\n<h5>five</h5>', const [
HeadingNode(level: HeadingLevel.h1, links: null, nodes: [TextNode('one')]),
HeadingNode(level: HeadingLevel.h2, links: null, nodes: [TextNode('two')]),
HeadingNode(level: HeadingLevel.h3, links: null, nodes: [TextNode('three')]),
HeadingNode(level: HeadingLevel.h4, links: null, nodes: [TextNode('four')]),
HeadingNode(level: HeadingLevel.h5, links: null, nodes: [TextNode('five')]),
]);
});

Expand Down
20 changes: 20 additions & 0 deletions test/widgets/content_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,26 @@ import 'page_checks.dart';
void main() {
TestZulipBinding.ensureInitialized();

group('Heading', () {
Future<void> prepareContent(WidgetTester tester, String html) async {
await tester.pumpWidget(MaterialApp(home: BlockContentList(nodes: parseContent(html).nodes)));
}

testWidgets('plain h6', (tester) async {
await prepareContent(tester,
// "###### six"
'<h6>six</h6>');
tester.widget(find.text('six'));
});

testWidgets('smoke test for h1, h2, h3, h4, h5', (tester) async {
await prepareContent(tester,
// "# one\n## two\n### three\n#### four\n##### five"
'<h1>one</h1>\n<h2>two</h2>\n<h3>three</h3>\n<h4>four</h4>\n<h5>five</h5>');
check(find.byType(Heading).evaluate()).length.equals(5);
});
});

group("CodeBlock", () {
Future<void> prepareContent(WidgetTester tester, String html) async {
await tester.pumpWidget(MaterialApp(home: BlockContentList(nodes: parseContent(html).nodes)));
Expand Down

0 comments on commit d413ffd

Please sign in to comment.