mirror of
https://github.com/Ryubing/Ryujinx.git
synced 2025-03-15 00:34:47 +00:00
* 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>
57 lines
1.8 KiB
C#
57 lines
1.8 KiB
C#
using Gtk;
|
|
using Ryujinx.UI.Common.Configuration;
|
|
using System;
|
|
using System.Reflection;
|
|
using GUI = Gtk.Builder.ObjectAttribute;
|
|
|
|
namespace Ryujinx.UI.Widgets
|
|
{
|
|
public class ProfileDialog : Dialog
|
|
{
|
|
public string FileName { get; private set; }
|
|
|
|
#pragma warning disable CS0649, IDE0044 // Field is never assigned to, Add readonly modifier
|
|
[GUI] Entry _profileEntry;
|
|
[GUI] Label _errorMessage;
|
|
#pragma warning restore CS0649, IDE0044
|
|
|
|
public ProfileDialog() : this(new Builder("Ryujinx.Gtk3.UI.Widgets.ProfileDialog.glade")) { }
|
|
|
|
private ProfileDialog(Builder builder) : base(builder.GetRawOwnedObject("_profileDialog"))
|
|
{
|
|
builder.Autoconnect(this);
|
|
Icon = new Gdk.Pixbuf(Assembly.GetAssembly(typeof(ConfigurationState)), "Ryujinx.UI.Common.Resources.Logo_Ryujinx.png");
|
|
}
|
|
|
|
private void OkToggle_Activated(object sender, EventArgs args)
|
|
{
|
|
((ToggleButton)sender).SetStateFlags(StateFlags.Normal, true);
|
|
|
|
bool validFileName = true;
|
|
|
|
foreach (char invalidChar in System.IO.Path.GetInvalidFileNameChars())
|
|
{
|
|
if (_profileEntry.Text.Contains(invalidChar))
|
|
{
|
|
validFileName = false;
|
|
}
|
|
}
|
|
|
|
if (validFileName && !string.IsNullOrEmpty(_profileEntry.Text))
|
|
{
|
|
FileName = $"{_profileEntry.Text}.json";
|
|
|
|
Respond(ResponseType.Ok);
|
|
}
|
|
else
|
|
{
|
|
_errorMessage.Text = "The file name contains invalid characters. Please try again.";
|
|
}
|
|
}
|
|
|
|
private void CancelToggle_Activated(object sender, EventArgs args)
|
|
{
|
|
Respond(ResponseType.Cancel);
|
|
}
|
|
}
|
|
}
|