Credits window to XAML UI (#4622)

This commit is contained in:
Visne
2021-09-17 18:10:24 +02:00
committed by GitHub
parent 70260c21b5
commit a993af07c7
2 changed files with 54 additions and 87 deletions

View File

@@ -0,0 +1,30 @@
<SS14Window xmlns="https://spacestation14.io"
Title="{Loc 'credits-window-title'}"
SetSize="650 650" >
<TabContainer>
<ScrollContainer Name="Ss14ContributorsTab"
HScrollEnabled="False">
<BoxContainer Name="Ss14ContributorsContainer"
Orientation="Vertical"
Margin="2 2 0 0">
<!-- Contributors get added here by code -->
</BoxContainer>
</ScrollContainer>
<ScrollContainer Name="PatronsTab"
HScrollEnabled="False">
<BoxContainer Name="PatronsContainer"
Orientation="Vertical"
Margin="2 2 0 0">
<!-- Patrons get added here by code -->
</BoxContainer>
</ScrollContainer>
<ScrollContainer Name="LicensesTab"
HScrollEnabled="False">
<BoxContainer Name="LicensesContainer"
Orientation="Vertical"
Margin="2 2 0 0">
<!-- Licenses get added here by code -->
</BoxContainer>
</ScrollContainer>
</TabContainer>
</SS14Window>

View File

@@ -1,15 +1,15 @@
using System.Collections.Generic;
using System.IO;
using System.Linq;
using Content.Client.Links;
using Content.Client.Stylesheets;
using Content.Shared;
using Content.Shared.CCVar;
using Robust.Client.AutoGenerated;
using Robust.Client.Credits;
using Robust.Client.ResourceManagement;
using Robust.Client.UserInterface;
using Robust.Client.UserInterface.Controls;
using Robust.Client.UserInterface.CustomControls;
using Robust.Client.UserInterface.XAML;
using Robust.Shared.Configuration;
using Robust.Shared.IoC;
using Robust.Shared.Localization;
@@ -20,7 +20,8 @@ using static Robust.Client.UserInterface.Controls.BoxContainer;
namespace Content.Client.Credits
{
public sealed class CreditsWindow : SS14Window
[GenerateTypedNameReferences]
public sealed partial class CreditsWindow : SS14Window
{
[Dependency] private readonly IResourceCache _resourceManager = default!;
[Dependency] private readonly IConfigurationManager _cfg = default!;
@@ -35,71 +36,34 @@ namespace Content.Client.Credits
public CreditsWindow()
{
IoCManager.InjectDependencies(this);
RobustXamlLoader.Load(this);
Title = Loc.GetString("credits-window-title");
TabContainer.SetTabTitle(Ss14ContributorsTab, Loc.GetString("credits-window-ss14contributorslist-tab"));
TabContainer.SetTabTitle(PatronsTab, Loc.GetString("credits-window-patrons-tab"));
TabContainer.SetTabTitle(LicensesTab, Loc.GetString("credits-window-licenses-tab"));
var rootContainer = new TabContainer();
var patronsList = new ScrollContainer
{
HScrollEnabled = false
};
var ss14ContributorsList = new ScrollContainer
{
HScrollEnabled = false
};
var licensesList = new ScrollContainer
{
HScrollEnabled = false
};
rootContainer.AddChild(ss14ContributorsList);
rootContainer.AddChild(patronsList);
rootContainer.AddChild(licensesList);
TabContainer.SetTabTitle(patronsList, Loc.GetString("credits-window-patrons-tab"));
TabContainer.SetTabTitle(ss14ContributorsList, Loc.GetString("credits-window-ss14contributorslist-tab"));
TabContainer.SetTabTitle(licensesList, Loc.GetString("credits-window-licenses-tab"));
PopulatePatronsList(patronsList);
PopulateCredits(ss14ContributorsList);
PopulateLicenses(licensesList);
Contents.AddChild(rootContainer);
SetSize = (650, 650);
PopulateContributors(Ss14ContributorsContainer);
PopulatePatrons(PatronsContainer);
PopulateLicenses(LicensesContainer);
}
private void PopulateLicenses(ScrollContainer licensesList)
private void PopulateLicenses(BoxContainer licensesContainer)
{
var vBox = new BoxContainer
{
Orientation = LayoutOrientation.Vertical,
Margin = new Thickness(2, 2, 0, 0)
};
foreach (var entry in CreditsManager.GetLicenses().OrderBy(p => p.Name))
{
vBox.AddChild(new Label {StyleClasses = {StyleBase.StyleClassLabelHeading}, Text = entry.Name});
licensesContainer.AddChild(new Label {StyleClasses = {StyleBase.StyleClassLabelHeading}, Text = entry.Name});
// We split these line by line because otherwise
// the LGPL causes Clyde to go out of bounds in the rendering code.
foreach (var line in entry.License.Split("\n"))
{
vBox.AddChild(new Label {Text = line, FontColorOverride = new Color(200, 200, 200)});
licensesContainer.AddChild(new Label {Text = line, FontColorOverride = new Color(200, 200, 200)});
}
}
}
licensesList.AddChild(vBox);
}
private void PopulatePatronsList(Control patronsList)
private void PopulatePatrons(BoxContainer patronsContainer)
{
var vBox = new BoxContainer
{
Orientation = LayoutOrientation.Vertical,
Margin = new Thickness(2, 2, 0, 0)
};
var patrons = LoadPatrons();
// Do not show "become a patron" button on Steam builds
@@ -107,7 +71,7 @@ namespace Content.Client.Credits
if (!_cfg.GetCVar(CCVars.BrandingSteam))
{
Button patronButton;
vBox.AddChild(patronButton = new Button
patronsContainer.AddChild(patronButton = new Button
{
Text = Loc.GetString("credits-window-become-patron-button"),
HorizontalAlignment = HAlignment.Center
@@ -122,23 +86,19 @@ namespace Content.Client.Credits
{
if (!first)
{
vBox.AddChild(new Control {MinSize = (0, 10)});
patronsContainer.AddChild(new Control {MinSize = (0, 10)});
}
first = false;
vBox.AddChild(new Label {StyleClasses = {StyleBase.StyleClassLabelHeading}, Text = $"{tier.Key}"});
patronsContainer.AddChild(new Label {StyleClasses = {StyleBase.StyleClassLabelHeading}, Text = $"{tier.Key}"});
var msg = string.Join(", ", tier.OrderBy(p => p.Name).Select(p => p.Name));
var label = new RichTextLabel();
label.SetMessage(msg);
vBox.AddChild(label);
patronsContainer.AddChild(label);
}
patronsList.AddChild(vBox);
}
private IEnumerable<PatronEntry> LoadPatrons()
@@ -151,17 +111,11 @@ namespace Content.Client.Credits
.Select(m => new PatronEntry(m["Name"].AsString(), m["Tier"].AsString()));
}
private void PopulateCredits(Control contributorsList)
private void PopulateContributors(BoxContainer ss14ContributorsContainer)
{
Button contributeButton;
var vBox = new BoxContainer
{
Orientation = LayoutOrientation.Vertical,
Margin = new Thickness(2, 2, 0, 0)
};
vBox.AddChild(new BoxContainer
ss14ContributorsContainer.AddChild(new BoxContainer
{
Orientation = LayoutOrientation.Horizontal,
HorizontalAlignment = HAlignment.Center,
@@ -179,11 +133,11 @@ namespace Content.Client.Credits
{
if (!first)
{
vBox.AddChild(new Control {MinSize = (0, 10)});
ss14ContributorsContainer.AddChild(new Control {MinSize = (0, 10)});
}
first = false;
vBox.AddChild(new Label {StyleClasses = {StyleBase.StyleClassLabelHeading}, Text = title});
ss14ContributorsContainer.AddChild(new Label {StyleClasses = {StyleBase.StyleClassLabelHeading}, Text = title});
var label = new RichTextLabel();
var text = _resourceManager.ContentFileReadAllText($"/Credits/{path}");
@@ -196,7 +150,7 @@ namespace Content.Client.Credits
label.SetMessage(text);
}
vBox.AddChild(label);
ss14ContributorsContainer.AddChild(label);
}
AddSection(Loc.GetString("credits-window-contributors-section-title"), "GitHub.txt");
@@ -204,27 +158,10 @@ namespace Content.Client.Credits
AddSection(Loc.GetString("credits-window-original-remake-team-section-title"), "OriginalRemake.txt");
AddSection(Loc.GetString("credits-window-special-thanks-section-title"), "SpecialThanks.txt", true);
contributorsList.AddChild(vBox);
contributeButton.OnPressed += _ =>
IoCManager.Resolve<IUriOpener>().OpenUri(UILinks.GitHub);
}
// TODO this doesn't looked used anywhere
private static IEnumerable<string> Lines(TextReader reader)
{
while (true)
{
var line = reader.ReadLine();
if (line == null)
{
yield break;
}
yield return line;
}
}
private sealed class PatronEntry
{
public string Name { get; }