* dotnet format style --severity info Some changes were manually reverted. * dotnet format analyzers --serverity info Some changes have been minimally adapted. * Restore a few unused methods and variables * Silence dotnet format IDE0060 warnings * Silence dotnet format IDE0052 warnings * Silence dotnet format IDE0059 warnings * Address or silence dotnet format IDE1006 warnings * Address dotnet format CA1816 warnings * Address dotnet format CA1822 warnings * Address or silence dotnet format CA1069 warnings * Make dotnet format succeed in style mode * Address dotnet format CA1401 warnings * Address remaining dotnet format analyzer warnings * Address review comments * dotnet-format fixes after rebase * Address most dotnet format whitespace warnings * Apply dotnet format whitespace formatting A few of them have been manually reverted and the corresponding warning was silenced * Format if-blocks correctly * Another rebase, another dotnet format run * Run dotnet format whitespace after rebase * Run dotnet format style after rebase * Run dotnet format after rebase and remove unused usings - analyzers - style - whitespace * Add comments to disabled warnings * Remove a few unused parameters * Simplify properties and array initialization, Use const when possible, Remove trailing commas * Start working on disabled warnings * Fix and silence a few dotnet-format warnings again * Address IDE0260 warnings * Address a few disabled IDE0060 warnings * Silence IDE0060 in .editorconfig * Revert "Simplify properties and array initialization, Use const when possible, Remove trailing commas" This reverts commit 9462e4136c0a2100dc28b20cf9542e06790aa67e. * dotnet format whitespace after rebase * dotnet format pass with new editorconfig * Fix naming style issues * Apply suggestions from code review Co-authored-by: Ac_K <Acoustik666@gmail.com> * Revert one suggestion * Second dotnet format pass and fix build issues * Final pass of dotnet format * Add trailing commas * Fix formatting issues * Keep unnecessary assignment in IconColorPicker.cs * Use using declarations and extend resource lifetimes * Fix rebase issues * Adjust comment spacing * Fix typo * Fix naming issues * Apply suggestions from code review Co-authored-by: Ac_K <Acoustik666@gmail.com> * Revert unintentional change * Remove unused file * Remove static keyword from ViewModels Binding of static members doesn't work and is silently ignored. --------- Co-authored-by: Ac_K <Acoustik666@gmail.com>
91 lines
3.7 KiB
C#
91 lines
3.7 KiB
C#
using Ryujinx.Ava.Common.Locale;
|
|
using Ryujinx.Ui.Common;
|
|
using Ryujinx.Ui.Common.Helper;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace Ryujinx.Ava.UI.Helpers
|
|
{
|
|
internal class UserErrorDialog
|
|
{
|
|
private const string SetupGuideUrl = "https://github.com/Ryujinx/Ryujinx/wiki/Ryujinx-Setup-&-Configuration-Guide";
|
|
|
|
private static string GetErrorCode(UserError error)
|
|
{
|
|
return $"RYU-{(uint)error:X4}";
|
|
}
|
|
|
|
private static string GetErrorTitle(UserError error)
|
|
{
|
|
return error switch
|
|
{
|
|
UserError.NoKeys => LocaleManager.Instance[LocaleKeys.UserErrorNoKeys],
|
|
UserError.NoFirmware => LocaleManager.Instance[LocaleKeys.UserErrorNoFirmware],
|
|
UserError.FirmwareParsingFailed => LocaleManager.Instance[LocaleKeys.UserErrorFirmwareParsingFailed],
|
|
UserError.ApplicationNotFound => LocaleManager.Instance[LocaleKeys.UserErrorApplicationNotFound],
|
|
UserError.Unknown => LocaleManager.Instance[LocaleKeys.UserErrorUnknown],
|
|
_ => LocaleManager.Instance[LocaleKeys.UserErrorUndefined],
|
|
};
|
|
}
|
|
|
|
private static string GetErrorDescription(UserError error)
|
|
{
|
|
return error switch
|
|
{
|
|
UserError.NoKeys => LocaleManager.Instance[LocaleKeys.UserErrorNoKeysDescription],
|
|
UserError.NoFirmware => LocaleManager.Instance[LocaleKeys.UserErrorNoFirmwareDescription],
|
|
UserError.FirmwareParsingFailed => LocaleManager.Instance[LocaleKeys.UserErrorFirmwareParsingFailedDescription],
|
|
UserError.ApplicationNotFound => LocaleManager.Instance[LocaleKeys.UserErrorApplicationNotFoundDescription],
|
|
UserError.Unknown => LocaleManager.Instance[LocaleKeys.UserErrorUnknownDescription],
|
|
_ => LocaleManager.Instance[LocaleKeys.UserErrorUndefinedDescription],
|
|
};
|
|
}
|
|
|
|
private static bool IsCoveredBySetupGuide(UserError error)
|
|
{
|
|
return error switch
|
|
{
|
|
UserError.NoKeys or
|
|
UserError.NoFirmware or
|
|
UserError.FirmwareParsingFailed => true,
|
|
_ => false,
|
|
};
|
|
}
|
|
|
|
private static string GetSetupGuideUrl(UserError error)
|
|
{
|
|
if (!IsCoveredBySetupGuide(error))
|
|
{
|
|
return null;
|
|
}
|
|
|
|
return error switch
|
|
{
|
|
UserError.NoKeys => SetupGuideUrl + "#initial-setup---placement-of-prodkeys",
|
|
UserError.NoFirmware => SetupGuideUrl + "#initial-setup-continued---installation-of-firmware",
|
|
_ => SetupGuideUrl,
|
|
};
|
|
}
|
|
|
|
public static async Task ShowUserErrorDialog(UserError error)
|
|
{
|
|
string errorCode = GetErrorCode(error);
|
|
|
|
bool isInSetupGuide = IsCoveredBySetupGuide(error);
|
|
|
|
string setupButtonLabel = isInSetupGuide ? LocaleManager.Instance[LocaleKeys.OpenSetupGuideMessage] : "";
|
|
|
|
var result = await ContentDialogHelper.CreateInfoDialog(
|
|
LocaleManager.Instance.UpdateAndGetDynamicValue(LocaleKeys.DialogUserErrorDialogMessage, errorCode, GetErrorTitle(error)),
|
|
GetErrorDescription(error) + (isInSetupGuide
|
|
? LocaleManager.Instance[LocaleKeys.DialogUserErrorDialogInfoMessage]
|
|
: ""), setupButtonLabel, LocaleManager.Instance[LocaleKeys.InputDialogOk],
|
|
LocaleManager.Instance.UpdateAndGetDynamicValue(LocaleKeys.DialogUserErrorDialogTitle, errorCode));
|
|
|
|
if (result == UserResult.Ok)
|
|
{
|
|
OpenHelper.OpenUrl(GetSetupGuideUrl(error));
|
|
}
|
|
}
|
|
}
|
|
}
|