Jumboable emojis

pull/162/head
Alexey Golub 6 years ago
parent 666f2d8d4a
commit 0d1ce38489

@ -77,7 +77,7 @@ namespace DiscordChatExporter.Core.Services
private string FormatDate(DateTime dateTime) => Format(dateTime, _dateFormat); private string FormatDate(DateTime dateTime) => Format(dateTime, _dateFormat);
private string FormatMarkdownPlainText(IEnumerable<Node> nodes) private string FormatMarkdownPlainText(IReadOnlyList<Node> nodes)
{ {
var buffer = new StringBuilder(); var buffer = new StringBuilder();
@ -127,7 +127,7 @@ namespace DiscordChatExporter.Core.Services
private string FormatMarkdownPlainText(string input) private string FormatMarkdownPlainText(string input)
=> FormatMarkdownPlainText(MarkdownParser.Parse(input)); => FormatMarkdownPlainText(MarkdownParser.Parse(input));
private string FormatMarkdownHtml(IEnumerable<Node> nodes) private string FormatMarkdownHtml(IReadOnlyList<Node> nodes, int depth = 0)
{ {
var buffer = new StringBuilder(); var buffer = new StringBuilder();
@ -140,7 +140,7 @@ namespace DiscordChatExporter.Core.Services
else if (node is FormattedNode formattedNode) else if (node is FormattedNode formattedNode)
{ {
var innerHtml = FormatMarkdownHtml(formattedNode.Children); var innerHtml = FormatMarkdownHtml(formattedNode.Children, depth + 1);
if (formattedNode.Formatting == TextFormatting.Bold) if (formattedNode.Formatting == TextFormatting.Bold)
buffer.Append($"<strong>{innerHtml}</strong>"); buffer.Append($"<strong>{innerHtml}</strong>");
@ -165,6 +165,7 @@ namespace DiscordChatExporter.Core.Services
else if (node is MultilineCodeBlockNode multilineCodeBlockNode) else if (node is MultilineCodeBlockNode multilineCodeBlockNode)
{ {
// Set language class for syntax highlighting
var languageCssClass = multilineCodeBlockNode.Language.IsNotBlank() var languageCssClass = multilineCodeBlockNode.Language.IsNotBlank()
? "language-" + multilineCodeBlockNode.Language ? "language-" + multilineCodeBlockNode.Language
: null; : null;
@ -201,8 +202,15 @@ namespace DiscordChatExporter.Core.Services
else if (node is EmojiNode emojiNode) else if (node is EmojiNode emojiNode)
{ {
var emoji = new Emoji(emojiNode.Id, emojiNode.Name, emojiNode.IsAnimated); // Get emoji image URL
buffer.Append($"<img class=\"emoji\" title=\"{emoji.Name}\" src=\"{emoji.ImageUrl}\" />"); var emojiImageUrl = new Emoji(emojiNode.Id, emojiNode.Name, emojiNode.IsAnimated).ImageUrl;
// Emoji can be jumboable if it's the only top-level node
var jumboableCssClass = depth == 0 && nodes.Count == 1
? "emoji--large"
: null;
buffer.Append($"<img class=\"emoji {jumboableCssClass}\" title=\"{emojiNode.Name}\" src=\"{emojiImageUrl}\" />");
} }
else if (node is LinkNode linkNode) else if (node is LinkNode linkNode)

Loading…
Cancel
Save