Skip to content

Commit

Permalink
Merge pull request #2281 from andy840119/implement-badge-in-markdown-…
Browse files Browse the repository at this point in the history
…container

Add special badge at the start of the changelog item.
  • Loading branch information
andy840119 authored Sep 10, 2024
2 parents 1eb6c94 + d20366d commit d17803d
Show file tree
Hide file tree
Showing 5 changed files with 161 additions and 38 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
// See the LICENCE file in the repository root for full licence text.

using System;
using System.Text.RegularExpressions;

namespace osu.Game.Rulesets.Karaoke.Online.API.Requests.Responses;

Expand Down Expand Up @@ -76,4 +77,14 @@ public APIChangelogBuild CreateBuildWithContent(string content)
PublishedAt = PublishedAt,
};
}

public string? GetFormattedContent()
{
if (Content == null)
return null;

// for able to parsing the badge, need to replace the " [content] " with " [content](content) ";
const string pattern = @"(?<=\s)\[(.*?)\](?=\s)";
return Regex.Replace(Content, pattern, m => $"[{m.Groups[1].Value}]({m.Groups[1].Value})");
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,14 @@
using System.Linq;
using Markdig.Syntax.Inlines;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Colour;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Layout;
using osu.Game.Graphics;
using osu.Game.Graphics.Containers.Markdown;
using osu.Game.Graphics.Sprites;
using osu.Game.Rulesets.Karaoke.Online.API.Requests.Responses;
using osuTK;

Expand All @@ -20,7 +24,7 @@ public ChangeLogMarkdownContainer(APIChangelogBuild build)
{
DocumentUrl = build.DocumentUrl;
RootUrl = build.RootUrl;
Text = build.Content;
Text = build.GetFormattedContent();
}

public override OsuMarkdownTextFlowContainer CreateTextFlow() => new ChangeLogMarkdownTextFlowContainer();
Expand All @@ -44,27 +48,41 @@ protected override void AddLinkText(string text, LinkInline linkInline)

var pullRequestInfo = ChangelogPullRequestInfo.GetPullRequestInfoFromLink(text, linkInline.Url);

if (pullRequestInfo == null)
if (pullRequestInfo != null)
{
base.AddLinkText(text, linkInline);
addPullRequestInfo(pullRequestInfo);
return;
}

var badgeInfo = ChangelogBadgeInfo.GetBadgeInfoFromLink(text);

if (badgeInfo != null)
{
addBadgeInfo(badgeInfo);
return;
}

base.AddLinkText(text, linkInline);
}

private void addPullRequestInfo(ChangelogPullRequestInfo pullRequestInfo)
{
var pullRequests = pullRequestInfo.PullRequests;
var users = pullRequestInfo.Users;

if (pullRequests.Any())
{
AddText("(");

foreach (var pullRequest in pullRequests)
for (int index = 0; index < pullRequests.Length; index++)
{
AddDrawable(new OsuMarkdownLinkText($"{text}#{pullRequest.Number}", new LinkInline
var pullRequest = pullRequests[index];
AddDrawable(new OsuMarkdownLinkText($"{pullRequestInfo.RepoName}#{pullRequest.Number}", new LinkInline
{
Url = pullRequest.Url,
}));

if (pullRequest != pullRequests.LastOrDefault())
if (index != pullRequests.Length - 1)
AddText(", ");
}

Expand All @@ -81,7 +99,7 @@ protected override void AddLinkText(string text, LinkInline linkInline)
});
AddDrawable(new UserLinkText(user.UserName, new LinkInline
{
Url = user.UserUrl,
Url = user.Url,
})
{
Scale = textScale,
Expand All @@ -90,6 +108,15 @@ protected override void AddLinkText(string text, LinkInline linkInline)
}
}

private void addBadgeInfo(ChangelogBadgeInfo badgeInfo)
{
AddDrawable(new Badge
{
BadgeText = badgeInfo.Text,
BadgeColour = badgeInfo.Color,
});
}

/// <summary>
/// Override <see cref="OsuMarkdownImage"/> to limit image display size
/// </summary>
Expand Down Expand Up @@ -145,5 +172,46 @@ public UserLinkText(string text, LinkInline linkInline)
Padding = new MarginPadding { Top = 6 };
}
}

private partial class Badge : CompositeDrawable
{
private readonly Box background;
private readonly OsuSpriteText text;

public Badge()
{
AutoSizeAxes = Axes.Both;
Masking = true;
CornerRadius = 5;

InternalChildren = new Drawable[]
{
background = new Box
{
RelativeSizeAxes = Axes.Both,
Colour = Colour4.White,
},
text = new OsuSpriteText
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Font = OsuFont.GetFont(size: 12, weight: FontWeight.Bold),
Margin = new MarginPadding { Horizontal = 5, Vertical = 3 },
},
};
}

public ColourInfo BadgeColour
{
get => background.Colour;
set => background.Colour = value;
}

public string BadgeText
{
get => text.Text.ToString();
set => text.Text = value;
}
}
}
}
43 changes: 43 additions & 0 deletions osu.Game.Rulesets.Karaoke/Overlays/Changelog/ChangelogBadgeInfo.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
// Copyright (c) andy840119 <[email protected]>. Licensed under the GPL Licence.
// See the LICENCE file in the repository root for full licence text.

using System.Collections.Generic;
using osu.Framework.Extensions.Color4Extensions;
using osuTK.Graphics;

namespace osu.Game.Rulesets.Karaoke.Overlays.Changelog;

public class ChangelogBadgeInfo
{
// follow the definition in the https://github.com/karaoke-dev/karaoke-dev.github.io/blob/master/layouts/partials/script/badge.html
private static readonly IDictionary<string, string> colour_mappings = new Dictionary<string, string>
{
{ "outdated", "#808080" },
{ "rejected", "#FF0000" },
};

public Color4 Color { get; init; } = Color4.White;

public string Text { get; init; } = string.Empty;

/// <summary>
/// Trying to parse the badge from the text.
/// </summary>
/// <example>
/// [outdated]<br/>
/// [rejected]
/// </example>
/// <param name="text">Link text</param>
/// <returns></returns>
public static ChangelogBadgeInfo? GetBadgeInfoFromLink(string text)
{
if (!colour_mappings.TryGetValue(text, out string? repoUrl))
return null;

return new ChangelogBadgeInfo
{
Text = text,
Color = Color4Extensions.FromHex(repoUrl),
};
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -22,22 +22,35 @@ public class ChangelogPullRequestInfo
{ "font-package", "https://github.com/karaoke-dev/osu-framework-font/" },
};

public PullRequestInfo[] PullRequests { get; set; } = Array.Empty<PullRequestInfo>();
public string RepoName { get; init; } = string.Empty;

public UserInfo[] Users { get; set; } = Array.Empty<UserInfo>();
public PullRequestInfo[] PullRequests { get; init; } = Array.Empty<PullRequestInfo>();

public class PullRequestInfo
public UserInfo[] Users { get; init; } = Array.Empty<UserInfo>();

public readonly struct PullRequestInfo
{
public int Number { get; set; }
public PullRequestInfo(string repoName, int number)
{
Number = number;
Url = new Uri(new Uri(repo_urls[repoName]), $"pull/{number}").AbsoluteUri;
}

public int Number { get; } = 0;

public string Url { get; set; } = string.Empty;
public string Url { get; } = string.Empty;
}

public class UserInfo
public readonly struct UserInfo
{
public string UserName { get; set; } = string.Empty;
public UserInfo(string useName)
{
UserName = useName;
}

public string UserName { get; } = string.Empty;

public string UserUrl => $"https://github.com/{UserName}";
public string Url => $"https://github.com/{UserName}";
}

/// <summary>
Expand All @@ -50,20 +63,20 @@ public class UserInfo
/// @andy840119<br/>
/// @andy@andy840119
/// </example>
/// <param name="text">Link text</param>
/// <param name="url">Link url</param>
/// <param name="repo">Link text</param>
/// <param name="info">Link url</param>
/// <returns></returns>
public static ChangelogPullRequestInfo? GetPullRequestInfoFromLink(string text, string url)
public static ChangelogPullRequestInfo? GetPullRequestInfoFromLink(string repo, string info)
{
if (!repo_urls.ContainsKey(text))
if (!repo_urls.ContainsKey(repo))
return null;

const string pull_request_key = "pull_request";
const string username_key = "username";
const string pull_request_regex = $"#(?<{pull_request_key}>[0-9]+)|@(?<{username_key}>[0-9A-z]+)";

// note: should have at least one pr number or one username,
var result = Regex.Matches(url, pull_request_regex, RegexOptions.IgnoreCase);
var result = Regex.Matches(info, pull_request_regex, RegexOptions.IgnoreCase);
if (!result.Any())
return null;

Expand All @@ -77,21 +90,9 @@ public class UserInfo

return new ChangelogPullRequestInfo
{
PullRequests = prs.Select(x => generatePullRequestInfo(repo_urls[text], x)).ToArray(),
Users = usernames.Select(generateUserInfo).ToArray(),
RepoName = repo,
PullRequests = prs.Select(pr => new PullRequestInfo(repo, int.Parse(pr))).ToArray(),
Users = usernames.Select(userName => new UserInfo(userName)).ToArray(),
};

static PullRequestInfo generatePullRequestInfo(string url, string pr) =>
new()
{
Number = int.Parse(pr),
Url = new Uri(new Uri(url), $"pull/{pr}").AbsoluteUri,
};

static UserInfo generateUserInfo(string username) =>
new()
{
UserName = username,
};
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,7 @@ private partial class TextIndexInfo : CompositeDrawable
{
private const int border_radius = 5;

private DrawableTimeTag currentTextTag = null!;
private DrawableTimeTag currentTimeTag = null!;
private FillFlowContainer<DrawableTimeTag> pendingTimeTags = null!;

[Resolved]
Expand Down Expand Up @@ -175,7 +175,7 @@ private void load(LyricEditorColourProvider colourProvider, ILyricEditorState st
RelativeSizeAxes = Axes.Both,
Colour = colourProvider.Background5(state.Mode),
},
currentTextTag = new DrawableTimeTag
currentTimeTag = new DrawableTimeTag
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Expand All @@ -199,7 +199,7 @@ private void load(LyricEditorColourProvider colourProvider, ILyricEditorState st

public void UpdateCaret(RecordingTimeTagCaretPosition caret)
{
currentTextTag.TimeTag = caret.TimeTag;
currentTimeTag.TimeTag = caret.TimeTag;

int paddingIndicator = caret.GetPaddingTextIndex();
pendingTimeTags.Clear();
Expand Down

0 comments on commit d17803d

Please sign in to comment.