Credits
This commit is contained in:
20
Content.Client/Commands/CreditsCommand.cs
Normal file
20
Content.Client/Commands/CreditsCommand.cs
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
using Content.Client.UserInterface;
|
||||||
|
using JetBrains.Annotations;
|
||||||
|
using Robust.Client.Interfaces.Console;
|
||||||
|
|
||||||
|
namespace Content.Client.Commands
|
||||||
|
{
|
||||||
|
[UsedImplicitly]
|
||||||
|
public sealed class CreditsCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "credits";
|
||||||
|
public string Description => "Opens the credits window";
|
||||||
|
public string Help => "credits";
|
||||||
|
|
||||||
|
public bool Execute(IDebugConsole console, params string[] args)
|
||||||
|
{
|
||||||
|
new CreditsWindow().Open();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -92,6 +92,7 @@ namespace Content.Client.State
|
|||||||
};
|
};
|
||||||
|
|
||||||
_lobby.LeaveButton.OnPressed += args => _console.ProcessCommand("disconnect");
|
_lobby.LeaveButton.OnPressed += args => _console.ProcessCommand("disconnect");
|
||||||
|
_lobby.CreditsButton.OnPressed += args => new CreditsWindow().Open();
|
||||||
|
|
||||||
UpdatePlayerList();
|
UpdatePlayerList();
|
||||||
|
|
||||||
|
|||||||
11
Content.Client/UILinks.cs
Normal file
11
Content.Client/UILinks.cs
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
namespace Content.Client
|
||||||
|
{
|
||||||
|
public static class UILinks
|
||||||
|
{
|
||||||
|
public const string GitHub = "https://github.com/space-wizards/space-station-14/";
|
||||||
|
public const string Patreon = "https://www.patreon.com/spacestation14";
|
||||||
|
|
||||||
|
public const string Discord = "https://discordapp.com/invite/t2jac3p";
|
||||||
|
public const string Website = "https://spacestation14.io";
|
||||||
|
}
|
||||||
|
}
|
||||||
219
Content.Client/UserInterface/CreditsWindow.cs
Normal file
219
Content.Client/UserInterface/CreditsWindow.cs
Normal file
@@ -0,0 +1,219 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using Content.Client.UserInterface.Stylesheets;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using Robust.Client.Credits;
|
||||||
|
using Robust.Client.Interfaces.ResourceManagement;
|
||||||
|
using Robust.Client.UserInterface;
|
||||||
|
using Robust.Client.UserInterface.Controls;
|
||||||
|
using Robust.Client.UserInterface.CustomControls;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
using Robust.Shared.Maths;
|
||||||
|
using Robust.Shared.Utility;
|
||||||
|
|
||||||
|
#nullable enable
|
||||||
|
|
||||||
|
namespace Content.Client.UserInterface
|
||||||
|
{
|
||||||
|
public sealed class CreditsWindow : SS14Window
|
||||||
|
{
|
||||||
|
[Dependency] private readonly IResourceCache _resourceManager = default!;
|
||||||
|
|
||||||
|
private static readonly Dictionary<string, int> PatronTierPriority = new Dictionary<string, int>
|
||||||
|
{
|
||||||
|
["Nuclear Operative"] = 1,
|
||||||
|
["Syndicate Agent"] = 2,
|
||||||
|
["Revolutionary"] = 3
|
||||||
|
};
|
||||||
|
|
||||||
|
public CreditsWindow()
|
||||||
|
{
|
||||||
|
IoCManager.InjectDependencies(this);
|
||||||
|
|
||||||
|
Title = Loc.GetString("Credits");
|
||||||
|
|
||||||
|
var rootContainer = new TabContainer();
|
||||||
|
|
||||||
|
var patronsList = new ScrollContainer();
|
||||||
|
var ss14ContributorsList = new ScrollContainer();
|
||||||
|
var licensesList = new ScrollContainer();
|
||||||
|
|
||||||
|
rootContainer.AddChild(ss14ContributorsList);
|
||||||
|
rootContainer.AddChild(patronsList);
|
||||||
|
rootContainer.AddChild(licensesList);
|
||||||
|
|
||||||
|
TabContainer.SetTabTitle(patronsList, Loc.GetString("Patrons"));
|
||||||
|
TabContainer.SetTabTitle(ss14ContributorsList, Loc.GetString("Credits"));
|
||||||
|
TabContainer.SetTabTitle(licensesList, Loc.GetString("Open Source Licenses"));
|
||||||
|
|
||||||
|
PopulatePatronsList(patronsList);
|
||||||
|
PopulateCredits(ss14ContributorsList);
|
||||||
|
PopulateLicenses(licensesList);
|
||||||
|
|
||||||
|
Contents.AddChild(rootContainer);
|
||||||
|
|
||||||
|
CustomMinimumSize = (650, 450);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void PopulateLicenses(ScrollContainer licensesList)
|
||||||
|
{
|
||||||
|
var margin = new MarginContainer {MarginLeftOverride = 2, MarginTopOverride = 2};
|
||||||
|
var vBox = new VBoxContainer();
|
||||||
|
margin.AddChild(vBox);
|
||||||
|
|
||||||
|
foreach (var entry in CreditsManager.GetLicenses().OrderBy(p => p.Name))
|
||||||
|
{
|
||||||
|
vBox.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)});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
licensesList.AddChild(margin);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void PopulatePatronsList(Control patronsList)
|
||||||
|
{
|
||||||
|
var margin = new MarginContainer {MarginLeftOverride = 2, MarginTopOverride = 2};
|
||||||
|
var vBox = new VBoxContainer();
|
||||||
|
margin.AddChild(vBox);
|
||||||
|
var patrons = ReadJson<PatronEntry[]>("/Credits/Patrons.json");
|
||||||
|
|
||||||
|
Button patronButton;
|
||||||
|
vBox.AddChild(patronButton = new Button
|
||||||
|
{
|
||||||
|
Text = "Become a Patron",
|
||||||
|
SizeFlagsHorizontal = SizeFlags.ShrinkCenter
|
||||||
|
});
|
||||||
|
|
||||||
|
var first = true;
|
||||||
|
foreach (var tier in patrons.GroupBy(p => p.Tier).OrderBy(p => PatronTierPriority[p.Key]))
|
||||||
|
{
|
||||||
|
if (!first)
|
||||||
|
{
|
||||||
|
vBox.AddChild(new Control {CustomMinimumSize = (0, 10)});
|
||||||
|
}
|
||||||
|
|
||||||
|
first = false;
|
||||||
|
vBox.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);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
patronButton.OnPressed +=
|
||||||
|
_ => IoCManager.Resolve<IUriOpener>().OpenUri(UILinks.Patreon);
|
||||||
|
|
||||||
|
patronsList.AddChild(margin);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void PopulateCredits(Control contributorsList)
|
||||||
|
{
|
||||||
|
Button contributeButton;
|
||||||
|
|
||||||
|
var margin = new MarginContainer
|
||||||
|
{
|
||||||
|
MarginLeftOverride = 2,
|
||||||
|
MarginTopOverride = 2
|
||||||
|
};
|
||||||
|
var vBox = new VBoxContainer();
|
||||||
|
margin.AddChild(vBox);
|
||||||
|
|
||||||
|
vBox.AddChild(new HBoxContainer
|
||||||
|
{
|
||||||
|
SizeFlagsHorizontal = SizeFlags.ShrinkCenter,
|
||||||
|
SeparationOverride = 20,
|
||||||
|
Children =
|
||||||
|
{
|
||||||
|
new Label {Text = "Want to get on this list?"},
|
||||||
|
(contributeButton = new Button {Text = "Contribute!"})
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
var first = true;
|
||||||
|
void AddSection(string title, string path, bool markup = false)
|
||||||
|
{
|
||||||
|
if (!first)
|
||||||
|
{
|
||||||
|
vBox.AddChild(new Control {CustomMinimumSize = (0, 10)});
|
||||||
|
}
|
||||||
|
|
||||||
|
first = false;
|
||||||
|
vBox.AddChild(new Label {StyleClasses = {StyleBase.StyleClassLabelHeading}, Text = title});
|
||||||
|
|
||||||
|
var label = new RichTextLabel();
|
||||||
|
var text = _resourceManager.ContentFileReadAllText($"/Credits/{path}");
|
||||||
|
if (markup)
|
||||||
|
{
|
||||||
|
label.SetMessage(FormattedMessage.FromMarkup(text.Trim()));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
label.SetMessage(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
vBox.AddChild(label);
|
||||||
|
}
|
||||||
|
|
||||||
|
AddSection("Space Station 14 Contributors", "GitHub.txt");
|
||||||
|
AddSection("Space Station 13 Codebases", "SpaceStation13.txt");
|
||||||
|
AddSection("Original Space Station 13 Remake Team", "OriginalRemake.txt");
|
||||||
|
AddSection("Special Thanks", "SpecialThanks.txt", true);
|
||||||
|
|
||||||
|
contributorsList.AddChild(margin);
|
||||||
|
|
||||||
|
contributeButton.OnPressed += _ =>
|
||||||
|
IoCManager.Resolve<IUriOpener>().OpenUri(UILinks.GitHub);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static IEnumerable<string> Lines(TextReader reader)
|
||||||
|
{
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
var line = reader.ReadLine();
|
||||||
|
if (line == null)
|
||||||
|
{
|
||||||
|
yield break;
|
||||||
|
}
|
||||||
|
|
||||||
|
yield return line;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private T ReadJson<T>(string path)
|
||||||
|
{
|
||||||
|
var serializer = new JsonSerializer();
|
||||||
|
|
||||||
|
using var stream = _resourceManager.ContentFileRead(path);
|
||||||
|
using var streamReader = new StreamReader(stream);
|
||||||
|
using var jsonTextReader = new JsonTextReader(streamReader);
|
||||||
|
|
||||||
|
return serializer.Deserialize<T>(jsonTextReader)!;
|
||||||
|
}
|
||||||
|
|
||||||
|
[JsonObject(ItemRequired = Required.Always)]
|
||||||
|
private sealed class PatronEntry
|
||||||
|
{
|
||||||
|
public string Name { get; set; } = default!;
|
||||||
|
public string Tier { get; set; } = default!;
|
||||||
|
}
|
||||||
|
|
||||||
|
[JsonObject(ItemRequired = Required.Always)]
|
||||||
|
private sealed class OpenSourceLicense
|
||||||
|
{
|
||||||
|
public string Name { get; set; } = default!;
|
||||||
|
public string License { get; set; } = default!;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -18,6 +18,7 @@ namespace Content.Client.UserInterface
|
|||||||
public Label StartTime { get; }
|
public Label StartTime { get; }
|
||||||
public Button ReadyButton { get; }
|
public Button ReadyButton { get; }
|
||||||
public Button ObserveButton { get; }
|
public Button ObserveButton { get; }
|
||||||
|
public Button CreditsButton { get; }
|
||||||
public Button LeaveButton { get; }
|
public Button LeaveButton { get; }
|
||||||
public ChatBox Chat { get; }
|
public ChatBox Chat { get; }
|
||||||
public ItemList OnlinePlayerItemList { get; }
|
public ItemList OnlinePlayerItemList { get; }
|
||||||
@@ -85,6 +86,13 @@ namespace Content.Client.UserInterface
|
|||||||
VAlign = Label.VAlignMode.Center,
|
VAlign = Label.VAlignMode.Center,
|
||||||
SizeFlagsHorizontal = SizeFlags.Expand | SizeFlags.ShrinkCenter
|
SizeFlagsHorizontal = SizeFlags.Expand | SizeFlags.ShrinkCenter
|
||||||
}),
|
}),
|
||||||
|
(CreditsButton = new Button
|
||||||
|
{
|
||||||
|
SizeFlagsHorizontal = SizeFlags.ShrinkEnd,
|
||||||
|
Text = Loc.GetString("Credits"),
|
||||||
|
StyleClasses = {StyleNano.StyleClassButtonBig},
|
||||||
|
//GrowHorizontal = GrowDirection.Begin
|
||||||
|
}),
|
||||||
(LeaveButton = new Button
|
(LeaveButton = new Button
|
||||||
{
|
{
|
||||||
SizeFlagsHorizontal = SizeFlags.ShrinkEnd,
|
SizeFlagsHorizontal = SizeFlags.ShrinkEnd,
|
||||||
|
|||||||
@@ -8,9 +8,6 @@ namespace Content.Client.UserInterface
|
|||||||
{
|
{
|
||||||
public class ServerInfo : VBoxContainer
|
public class ServerInfo : VBoxContainer
|
||||||
{
|
{
|
||||||
private const string DiscordUrl = "https://discordapp.com/invite/t2jac3p";
|
|
||||||
private const string WebsiteUrl = "https://spacestation14.io";
|
|
||||||
|
|
||||||
private readonly RichTextLabel _richTextLabel;
|
private readonly RichTextLabel _richTextLabel;
|
||||||
|
|
||||||
public ServerInfo()
|
public ServerInfo()
|
||||||
@@ -27,10 +24,10 @@ namespace Content.Client.UserInterface
|
|||||||
var uriOpener = IoCManager.Resolve<IUriOpener>();
|
var uriOpener = IoCManager.Resolve<IUriOpener>();
|
||||||
|
|
||||||
var discordButton = new Button {Text = Loc.GetString("Join us on Discord!")};
|
var discordButton = new Button {Text = Loc.GetString("Join us on Discord!")};
|
||||||
discordButton.OnPressed += args => uriOpener.OpenUri(DiscordUrl);
|
discordButton.OnPressed += args => uriOpener.OpenUri(UILinks.Discord);
|
||||||
|
|
||||||
var websiteButton = new Button {Text = Loc.GetString("Website")};
|
var websiteButton = new Button {Text = Loc.GetString("Website")};
|
||||||
websiteButton.OnPressed += args => uriOpener.OpenUri(WebsiteUrl);
|
websiteButton.OnPressed += args => uriOpener.OpenUri(UILinks.Website);
|
||||||
|
|
||||||
buttons.AddChild(discordButton);
|
buttons.AddChild(discordButton);
|
||||||
buttons.AddChild(websiteButton);
|
buttons.AddChild(websiteButton);
|
||||||
|
|||||||
1
Resources/Credits/GitHub.txt
Normal file
1
Resources/Credits/GitHub.txt
Normal file
@@ -0,0 +1 @@
|
|||||||
|
20kdc, 4dplanner, Acruid, actioninja, AJCM-git, ancientpower, as334, avghdev, BGare, BobdaBiscuit, boiled-water-tsar, Bright0, brndd, CakeQ, CatTheSystem, CC-4477, Centronias, chairbender, clusterfack, Clyybber, collinlunn, ComicIronic, Cyberboss, DamianX, Daracke, deathrat, Decappi, Dezandor, dylanstrategie, fizzle7, Fouin, gbasood, gituhabu, GlassEclipse, h3half, halworsen, harikattar, Hugal31, ike709, Injazz, InquisitivePenguin, JiimBob, johnku1, kalanosh, lzimann, Macoron, metalgearsloth, micheel665, Miniwoffer, Moneyl, N3X15, NickPowers43, nullarmo, Pangogie, partyaddict, patrikturi, PaulRitter, Pireax, PJB3005, ProfanedBane, PrPleGoo, psykzz, Quantomicus, Qustinnus, RednoWCirabrab, RemieRichards, remove32, renodubois, Rockdtben, Rohesie, rok-povsic, SamV522, ScumbagDog, Serkket, ShadowCommander, SignalWalker, Silvertorch5, Soundwavesghost, SpaceManiac, spoogemonster, SweptWasTaken, Szunti, tentekal, thatrandomcanadianguy, theOperand, tkdrg, Tomeno, Tyler-IN, unusualcrow, UristMcDorf, volundr-, wixoaGit, YotaXP, ZelteHonor, ZNixian, Zth--, Zumorica
|
||||||
2
Resources/Credits/OriginalRemake.txt
Normal file
2
Resources/Credits/OriginalRemake.txt
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
For creating and releasing the original remake, which this project is based on:
|
||||||
|
DrSingh, Edad, Hamshot (Ben Guilbert), Keelin, Nannek (a wanker), Nyxation (Tyler Merta), Ostaf, Supernorn (Adam Riches), Synchronic (Joseph Riches), Tan Teck Weng, Volundr
|
||||||
1
Resources/Credits/Patrons.json
Normal file
1
Resources/Credits/Patrons.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
[{"Name":"Acvisy","Tier":"Syndicate Agent"},{"Name":"Arian Jafari","Tier":"Nuclear Operative"},{"Name":"Await Future","Tier":"Syndicate Agent"},{"Name":"Calvin Balke","Tier":"Nuclear Operative"},{"Name":"Crocs Enthusiast .","Tier":"Revolutionary"},{"Name":"Daniel Thompson","Tier":"Revolutionary"},{"Name":"dean","Tier":"Nuclear Operative"},{"Name":"Kyle Hipke","Tier":"Nuclear Operative"},{"Name":"LeoZ","Tier":"Revolutionary"},{"Name":"MetalClone","Tier":"Nuclear Operative"},{"Name":"NetGlitch","Tier":"Syndicate Agent"},{"Name":"Ninja","Tier":"Syndicate Agent"},{"Name":"ThatGuyGW","Tier":"Nuclear Operative"},{"Name":"Tomeno","Tier":"Revolutionary"},{"Name":"Trevor McConnell","Tier":"Nuclear Operative"},{"Name":"Tyler Young","Tier":"Nuclear Operative"}]
|
||||||
2
Resources/Credits/SpaceStation13.txt
Normal file
2
Resources/Credits/SpaceStation13.txt
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
For creating and maintaining this awesome game: Goonstation, /tg/station, Baystation12, CEV-Eris, /vg/station, and countless others.
|
||||||
|
Many art assets taken from various SS13 codebases under the CC-BY-SA-3.0 license. Goonstation assets licensed under CC-BY-SA-NC-30.
|
||||||
3
Resources/Credits/SpecialThanks.txt
Normal file
3
Resources/Credits/SpecialThanks.txt
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Exadv1 for creating Space Station 13.
|
||||||
|
All the uncountable people providing feedback and support throughout the community.
|
||||||
|
[color=white]You[/color], without whom there'd be no point to all this.
|
||||||
20
Tools/dump_github_contributors.ps1
Executable file
20
Tools/dump_github_contributors.ps1
Executable file
@@ -0,0 +1,20 @@
|
|||||||
|
#!/usr/bin/env pwsh
|
||||||
|
|
||||||
|
# TODO: This is definitely gonna stop being accurate when we get above 100 contributors on one of the repos.
|
||||||
|
$engineJson = (Invoke-WebRequest "https://api.github.com/repos/space-wizards/RobustToolbox/contributors?per_page=100").Content | convertfrom-json
|
||||||
|
$contentJson = (Invoke-WebRequest "https://api.github.com/repos/space-wizards/space-station-14/contributors?per_page=100").Content | convertfrom-json
|
||||||
|
|
||||||
|
if ($engineJson.Count -ge 100)
|
||||||
|
{
|
||||||
|
Write-Warning "Engine is reporting 100 contributors. It might not be a complete list due to API pagination!"
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($contentJson.Count -ge 100)
|
||||||
|
{
|
||||||
|
Write-Warning "Content is reporting 100 contributors. It might not be a complete list due to API pagination!"
|
||||||
|
}
|
||||||
|
|
||||||
|
$scriptDir = Split-Path -Path $MyInvocation.MyCommand.Definition -Parent
|
||||||
|
$bad = get-content $(join-path $scriptDir "ignored_github_contributors.txt")
|
||||||
|
|
||||||
|
($engineJson).login + ($contentJson).login | select -unique | where { $bad -notcontains $_ } | Sort-object | Join-String -Separator ", "
|
||||||
8
Tools/dump_patrons.ps1
Executable file
8
Tools/dump_patrons.ps1
Executable file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env pwsh
|
||||||
|
|
||||||
|
param([string]$csvPath)
|
||||||
|
|
||||||
|
# Dumps Patreon's CSV download into a JSON file the game reads.
|
||||||
|
|
||||||
|
# Have to trim patron names because apparently Patreon doesn't which is quite ridiculous.
|
||||||
|
Get-content $csvPath | ConvertFrom-Csv -Delimiter "," | select @{l="Name";e={$_.Name.Trim()}},Tier | ConvertTo-Json -Compress
|
||||||
3
Tools/ignored_github_contributors.txt
Normal file
3
Tools/ignored_github_contributors.txt
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
ZDDM
|
||||||
|
TYoung86
|
||||||
|
PJBot
|
||||||
Reference in New Issue
Block a user