diff --git a/Content.Client/Credits/CreditsWindow.xaml b/Content.Client/Credits/CreditsWindow.xaml
new file mode 100644
index 0000000000..027a795cbb
--- /dev/null
+++ b/Content.Client/Credits/CreditsWindow.xaml
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/Content.Client/Credits/CreditsWindow.cs b/Content.Client/Credits/CreditsWindow.xaml.cs
similarity index 60%
rename from Content.Client/Credits/CreditsWindow.cs
rename to Content.Client/Credits/CreditsWindow.xaml.cs
index b617f25fb1..2cd65733e9 100644
--- a/Content.Client/Credits/CreditsWindow.cs
+++ b/Content.Client/Credits/CreditsWindow.xaml.cs
@@ -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 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().OpenUri(UILinks.GitHub);
}
- // TODO this doesn't looked used anywhere
- private static IEnumerable 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; }