Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MarkdownTextBlock: Adds OnMarkdownParsed event #616

Open
wants to merge 4 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions components/MarkdownTextBlock/src/MarkdownParsedEventArgs.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.

using Markdig.Syntax;

namespace CommunityToolkit.Labs.WinUI.MarkdownTextBlock;

public sealed class MarkdownParsedEventArgs : EventArgs
{
public MarkdownDocument Document { get; }
public MarkdownParsedEventArgs(MarkdownDocument document)
{
Document = document;
}
}
19 changes: 19 additions & 0 deletions components/MarkdownTextBlock/src/MarkdownTextBlock.Events.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.

namespace CommunityToolkit.Labs.WinUI.MarkdownTextBlock;

partial class MarkdownTextBlock
{
/// <summary>
/// Event raised when a markdown link is clicked.
/// </summary>
public event EventHandler<LinkClickedEventArgs>? OnLinkClicked;

/// <summary>
/// Event raised when markdown is done parsing, with a complete MarkdownDocument.
/// It is always raised before the control renders the document.
/// </summary>
public event EventHandler<MarkdownParsedEventArgs>? OnMarkdownParsed;
}
38 changes: 38 additions & 0 deletions components/MarkdownTextBlock/src/MarkdownTextBlock.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,43 @@ public partial class MarkdownTextBlock : Control
private MyFlowDocument _document;
private WinUIRenderer? _renderer;

private static readonly DependencyProperty ConfigProperty = DependencyProperty.Register(
nameof(Config),
typeof(MarkdownConfig),
typeof(MarkdownTextBlock),
new PropertyMetadata(null, OnConfigChanged)
);

private static readonly DependencyProperty TextProperty = DependencyProperty.Register(
nameof(Text),
typeof(string),
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);
set => SetValue(ConfigProperty, value);
}

public string Text
{
get => (string)GetValue(TextProperty);
set => SetValue(TextProperty, value);
}

public MarkdownDocument? MarkdownDocument
{
get => (MarkdownDocument)GetValue(MarkdownDocumentProperty);
private set => SetValue(MarkdownDocumentProperty, value);
}

public event EventHandler<LinkClickedEventArgs>? OnLinkClicked;

internal void RaiseLinkClickedEvent(Uri uri) => OnLinkClicked?.Invoke(this, new LinkClickedEventArgs(uri));
Expand Down Expand Up @@ -89,6 +126,7 @@ private void ApplyText(bool rerender)
if (!string.IsNullOrEmpty(Text))
{
var parsedMarkdown = Markdown.Parse(Text, _pipeline);
OnMarkdownParsed?.Invoke(this, new MarkdownParsedEventArgs(this.MarkdownDocument));
this.MarkdownDocument = parsedMarkdown;
_renderer.Render(parsedMarkdown);
}
Expand Down
Loading