diff --git a/components/MarkdownTextBlock/src/CommunityToolkit.WinUI.Controls.MarkdownTextBlock.csproj b/components/MarkdownTextBlock/src/CommunityToolkit.WinUI.Controls.MarkdownTextBlock.csproj
index 6c3c77740..f9a01416e 100644
--- a/components/MarkdownTextBlock/src/CommunityToolkit.WinUI.Controls.MarkdownTextBlock.csproj
+++ b/components/MarkdownTextBlock/src/CommunityToolkit.WinUI.Controls.MarkdownTextBlock.csproj
@@ -21,9 +21,9 @@
-
-
-
+
+
+
diff --git a/components/MarkdownTextBlock/src/MarkdownTextBlock.xaml.cs b/components/MarkdownTextBlock/src/MarkdownTextBlock.xaml.cs
index eef90cf74..01e05751f 100644
--- a/components/MarkdownTextBlock/src/MarkdownTextBlock.xaml.cs
+++ b/components/MarkdownTextBlock/src/MarkdownTextBlock.xaml.cs
@@ -5,6 +5,7 @@
using CommunityToolkit.Labs.WinUI.MarkdownTextBlock.Renderers;
using CommunityToolkit.Labs.WinUI.MarkdownTextBlock.TextElements;
using Markdig;
+using Markdig.Syntax;
namespace CommunityToolkit.Labs.WinUI.MarkdownTextBlock;
@@ -30,6 +31,12 @@ public partial class MarkdownTextBlock : Control
typeof(MarkdownTextBlock),
new PropertyMetadata(null, OnTextChanged));
+ private static readonly DependencyProperty MarkdownDocumentProperty = DependencyProperty.Register(
+ nameof(MarkdownDocument),
+ typeof(MarkdownDocument),
+ typeof(MarkdownTextBlock),
+ new PropertyMetadata(null));
+
public MarkdownConfig Config
{
get => (MarkdownConfig)GetValue(ConfigProperty);
@@ -42,6 +49,12 @@ public string Text
set => SetValue(TextProperty, value);
}
+ public MarkdownDocument? MarkdownDocument
+ {
+ get => (MarkdownDocument)GetValue(MarkdownDocumentProperty);
+ private set => SetValue(MarkdownDocumentProperty, value);
+ }
+
public event EventHandler? OnLinkClicked;
internal void RaiseLinkClickedEvent(Uri uri) => OnLinkClicked?.Invoke(this, new LinkClickedEventArgs(uri));
@@ -102,8 +115,8 @@ private void ApplyText(bool rerender)
if (!string.IsNullOrEmpty(Text))
{
- var markdown = Markdown.Parse(Text, _pipeline);
- _renderer.Render(markdown);
+ this.MarkdownDocument = Markdown.Parse(Text, _pipeline);
+ _renderer.Render(this.MarkdownDocument);
}
}
}
diff --git a/components/MarkdownTextBlock/src/MarkdownThemes.cs b/components/MarkdownTextBlock/src/MarkdownThemes.cs
index ada70c9b4..a550f461f 100644
--- a/components/MarkdownTextBlock/src/MarkdownThemes.cs
+++ b/components/MarkdownTextBlock/src/MarkdownThemes.cs
@@ -49,12 +49,12 @@ public sealed class MarkdownThemes : DependencyObject
public FontWeight H6FontWeight { get; set; } = FontWeights.Normal;
- public Thickness H1Margin { get; set; } = new(0);
- public Thickness H2Margin { get; set; } = new(0);
- public Thickness H3Margin { get; set; } = new(0);
- public Thickness H4Margin { get; set; } = new(0);
- public Thickness H5Margin { get; set; } = new(0);
- public Thickness H6Margin { get; set; } = new(0);
+ public Thickness H1Margin { get; set; } = new(left: 0, top: 14, right: 0, bottom: 0);
+ public Thickness H2Margin { get; set; } = new(left: 0, top: 14, right: 0, bottom: 0);
+ public Thickness H3Margin { get; set; } = new(left: 0, top: 14, right: 0, bottom: 0);
+ public Thickness H4Margin { get; set; } = new(left: 0, top: 14, right: 0, bottom: 0);
+ public Thickness H5Margin { get; set; } = new(left: 0, top: 8, right: 0, bottom: 0);
+ public Thickness H6Margin { get; set; } = new(left: 0, top: 8, right: 0, bottom: 0);
public Brush InlineCodeBackground { get; set; } = (Brush)Application.Current.Resources["ExpanderHeaderBackground"];
public Brush InlineCodeForeground { get; set; } = (Brush)Application.Current.Resources["TextFillColorPrimaryBrush"];
diff --git a/components/MarkdownTextBlock/src/TextElements/MyList.cs b/components/MarkdownTextBlock/src/TextElements/MyList.cs
index fc381008b..46b15e1a8 100644
--- a/components/MarkdownTextBlock/src/TextElements/MyList.cs
+++ b/components/MarkdownTextBlock/src/TextElements/MyList.cs
@@ -45,6 +45,7 @@ public MyList(ListBlock listBlock)
}
_stackPanel.Orientation = Orientation.Vertical;
+ _stackPanel.Margin = new Thickness(left: 0, top: 8, right: 0, bottom: 8);
_container.Child = _stackPanel;
_paragraph.Inlines.Add(_container);
}
@@ -52,7 +53,8 @@ public MyList(ListBlock listBlock)
public void AddChild(IAddChild child)
{
var grid = new Grid();
- grid.ColumnDefinitions.Add(new ColumnDefinition() { Width = new GridLength(1, GridUnitType.Auto) });
+ grid.ColumnDefinitions.Add(new ColumnDefinition() { Width = new GridLength(20, GridUnitType.Pixel) });
+ grid.ColumnDefinitions.Add(new ColumnDefinition() { Width = new GridLength(10, GridUnitType.Pixel) });
grid.ColumnDefinitions.Add(new ColumnDefinition() { Width = new GridLength(1, GridUnitType.Star) });
string bullet;
if (_isOrdered)
@@ -79,11 +81,12 @@ public void AddChild(IAddChild child)
};
textBlock.SetValue(Grid.ColumnProperty, 0);
textBlock.VerticalAlignment = VerticalAlignment.Top;
+ textBlock.TextAlignment = TextAlignment.Right;
grid.Children.Add(textBlock);
var flowDoc = new MyFlowDocument();
flowDoc.AddChild(child);
- flowDoc.RichTextBlock.SetValue(Grid.ColumnProperty, 1);
+ flowDoc.RichTextBlock.SetValue(Grid.ColumnProperty, 2);
flowDoc.RichTextBlock.Padding = new Thickness(0);
flowDoc.RichTextBlock.VerticalAlignment = VerticalAlignment.Top;
grid.Children.Add(flowDoc.RichTextBlock);
diff --git a/components/MarkdownTextBlock/src/TextElements/MyThematicBreak.cs b/components/MarkdownTextBlock/src/TextElements/MyThematicBreak.cs
index c1f945ca1..bc06491b9 100644
--- a/components/MarkdownTextBlock/src/TextElements/MyThematicBreak.cs
+++ b/components/MarkdownTextBlock/src/TextElements/MyThematicBreak.cs
@@ -22,14 +22,14 @@ public MyThematicBreak(ThematicBreakBlock thematicBreakBlock)
_paragraph = new Paragraph();
var inlineUIContainer = new InlineUIContainer();
- var border = new Border();
- border.Width = 500;
- border.BorderThickness = new Thickness(1);
- border.Margin = new Thickness(0, 4, 0, 4);
- border.BorderBrush = new SolidColorBrush(Colors.Gray);
- border.Height = 1;
- border.HorizontalAlignment = HorizontalAlignment.Stretch;
- inlineUIContainer.Child = border;
+ Line line = new Line
+ {
+ Stretch = Stretch.Fill,
+ Stroke = new SolidColorBrush(Colors.Gray),
+ X2 = 1,
+ Margin = new Thickness(0, 12, 0, 12)
+ };
+ inlineUIContainer.Child = line;
_paragraph.Inlines.Add(inlineUIContainer);
}