aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Gtk3/UI/Windows/AboutWindow.cs
diff options
context:
space:
mode:
authorMary Guillemard <mary@mary.zone>2024-03-02 12:51:05 +0100
committerGitHub <noreply@github.com>2024-03-02 12:51:05 +0100
commitec6cb0abb4b7669895b6e96fd7581c93b5abd691 (patch)
tree128c862ff5faea0b219467656d4023bee7faefb5 /src/Ryujinx.Gtk3/UI/Windows/AboutWindow.cs
parent53b5985da6b9d7b281d9fc25b93bfd1d1918a107 (diff)
infra: Make Avalonia the default UI (#6375)1.1.1216
* misc: Move Ryujinx project to Ryujinx.Gtk3 This breaks release CI for now but that's fine. Signed-off-by: Mary Guillemard <mary@mary.zone> * misc: Move Ryujinx.Ava project to Ryujinx This breaks CI for now, but it's fine. Signed-off-by: Mary Guillemard <mary@mary.zone> * infra: Make Avalonia the default UI Should fix CI after the previous changes. GTK3 isn't build by the release job anymore, only by PR CI. This also ensure that the test-ava update package is still generated to allow update from the old testing channel. Signed-off-by: Mary Guillemard <mary@mary.zone> * Fix missing copy in create_app_bundle.sh Signed-off-by: Mary Guillemard <mary@mary.zone> * Fix syntax error Signed-off-by: Mary Guillemard <mary@mary.zone> --------- Signed-off-by: Mary Guillemard <mary@mary.zone>
Diffstat (limited to 'src/Ryujinx.Gtk3/UI/Windows/AboutWindow.cs')
-rw-r--r--src/Ryujinx.Gtk3/UI/Windows/AboutWindow.cs85
1 files changed, 85 insertions, 0 deletions
diff --git a/src/Ryujinx.Gtk3/UI/Windows/AboutWindow.cs b/src/Ryujinx.Gtk3/UI/Windows/AboutWindow.cs
new file mode 100644
index 00000000..f4bb533c
--- /dev/null
+++ b/src/Ryujinx.Gtk3/UI/Windows/AboutWindow.cs
@@ -0,0 +1,85 @@
+using Gtk;
+using Ryujinx.Common.Utilities;
+using Ryujinx.UI.Common.Helper;
+using System.Net.Http;
+using System.Net.NetworkInformation;
+using System.Reflection;
+using System.Threading.Tasks;
+
+namespace Ryujinx.UI.Windows
+{
+ public partial class AboutWindow : Window
+ {
+ public AboutWindow() : base($"Ryujinx {Program.Version} - About")
+ {
+ Icon = new Gdk.Pixbuf(Assembly.GetAssembly(typeof(OpenHelper)), "Ryujinx.UI.Common.Resources.Logo_Ryujinx.png");
+ InitializeComponent();
+
+ _ = DownloadPatronsJson();
+ }
+
+ private async Task DownloadPatronsJson()
+ {
+ if (!NetworkInterface.GetIsNetworkAvailable())
+ {
+ _patreonNamesText.Buffer.Text = "Connection Error.";
+ }
+
+ HttpClient httpClient = new();
+
+ try
+ {
+ string patreonJsonString = await httpClient.GetStringAsync("https://patreon.ryujinx.org/");
+
+ _patreonNamesText.Buffer.Text = string.Join(", ", JsonHelper.Deserialize(patreonJsonString, CommonJsonContext.Default.StringArray));
+ }
+ catch
+ {
+ _patreonNamesText.Buffer.Text = "API Error.";
+ }
+ }
+
+ //
+ // Events
+ //
+ private void RyujinxButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://ryujinx.org");
+ }
+
+ private void AmiiboApiButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://amiiboapi.com");
+ }
+
+ private void PatreonButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://www.patreon.com/ryujinx");
+ }
+
+ private void GitHubButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://github.com/Ryujinx/Ryujinx");
+ }
+
+ private void DiscordButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://discordapp.com/invite/N2FmfVc");
+ }
+
+ private void TwitterButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://twitter.com/RyujinxEmu");
+ }
+
+ private void ContributorsButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://github.com/Ryujinx/Ryujinx/graphs/contributors?type=a");
+ }
+
+ private void ChangelogButton_Pressed(object sender, ButtonPressEventArgs args)
+ {
+ OpenHelper.OpenUrl("https://github.com/Ryujinx/Ryujinx/wiki/Changelog#ryujinx-changelog");
+ }
+ }
+}