From: sr55 Date: Wed, 25 Jul 2018 20:13:35 +0000 (+0100) Subject: WinGui: Make the error message nicer when the system clipboard is unavailable. #1498 X-Git-Tag: 1.2.0~224 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3e942937d7deb873df6f777d748f791e5fb95a05;p=handbrake WinGui: Make the error message nicer when the system clipboard is unavailable. #1498 --- diff --git a/win/CS/HandBrakeWPF/App.xaml.cs b/win/CS/HandBrakeWPF/App.xaml.cs index a3809bea7..60b1bf10e 100644 --- a/win/CS/HandBrakeWPF/App.xaml.cs +++ b/win/CS/HandBrakeWPF/App.xaml.cs @@ -19,6 +19,7 @@ namespace HandBrakeWPF using Caliburn.Micro; using HandBrakeWPF.Helpers; + using HandBrakeWPF.Services.Interfaces; using HandBrakeWPF.Startup; using HandBrakeWPF.Utilities; using HandBrakeWPF.ViewModels; @@ -175,9 +176,10 @@ namespace HandBrakeWPF try { IWindowManager windowManager = IoC.Get(); + IErrorService errorService = IoC.Get(); if (windowManager != null) { - ErrorViewModel errorView = new ErrorViewModel(); + ErrorViewModel errorView = new ErrorViewModel(errorService); GeneralApplicationException applicationException = null; if (exception.GetType() == typeof(GeneralApplicationException)) { diff --git a/win/CS/HandBrakeWPF/Properties/Resources.Designer.cs b/win/CS/HandBrakeWPF/Properties/Resources.Designer.cs index a22cf482b..bbe866be0 100644 --- a/win/CS/HandBrakeWPF/Properties/Resources.Designer.cs +++ b/win/CS/HandBrakeWPF/Properties/Resources.Designer.cs @@ -575,6 +575,24 @@ namespace HandBrakeWPF.Properties { } } + /// + /// Looks up a localized string similar to The system clipboard is currently unavailable.. + /// + public static string Clipboard_Unavailable { + get { + return ResourceManager.GetString("Clipboard_Unavailable", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to This may be due to another application monitoring or locking the clipboard for its own use. You will not be able to use the clipboard until it is unlocked.. + /// + public static string Clipboard_Unavailable_Solution { + get { + return ResourceManager.GetString("Clipboard_Unavailable_Solution", resourceCulture); + } + } + /// /// Looks up a localized string similar to Confirm. /// diff --git a/win/CS/HandBrakeWPF/Properties/Resources.resx b/win/CS/HandBrakeWPF/Properties/Resources.resx index 84d46f2b9..21bed46f7 100644 --- a/win/CS/HandBrakeWPF/Properties/Resources.resx +++ b/win/CS/HandBrakeWPF/Properties/Resources.resx @@ -885,4 +885,10 @@ Time Remaining: {5}, Elapsed: {6:d\:hh\:mm\:ss} The file '{0}' already exists! Would you like to overwrite it? + + The system clipboard is currently unavailable. + + + This may be due to another application monitoring or locking the clipboard for its own use. You will not be able to use the clipboard until it is unlocked. + \ No newline at end of file diff --git a/win/CS/HandBrakeWPF/ViewModels/ErrorViewModel.cs b/win/CS/HandBrakeWPF/ViewModels/ErrorViewModel.cs index be57cd804..ddea7a5e5 100644 --- a/win/CS/HandBrakeWPF/ViewModels/ErrorViewModel.cs +++ b/win/CS/HandBrakeWPF/ViewModels/ErrorViewModel.cs @@ -13,6 +13,7 @@ namespace HandBrakeWPF.ViewModels using System.Windows; using HandBrakeWPF.Properties; + using HandBrakeWPF.Services.Interfaces; using HandBrakeWPF.ViewModels.Interfaces; /// @@ -20,32 +21,20 @@ namespace HandBrakeWPF.ViewModels /// public class ErrorViewModel : ViewModelBase, IErrorViewModel { - #region Constants and Fields + private readonly IErrorService errorService; - /// - /// The details. - /// private string details; - - /// - /// The error message. - /// private string errorMessage; - - /// - /// The solution. - /// private string solution; - #endregion - #region Constructors and Destructors /// /// Initializes a new instance of the class. /// - public ErrorViewModel() + public ErrorViewModel(IErrorService errorService) { + this.errorService = errorService; this.Title = Resources.Error; this.ErrorMessage = Resources.ErrorViewModel_UnknownError; this.Details = Resources.ErrorViewModel_NoFurtherInformation; @@ -128,7 +117,14 @@ namespace HandBrakeWPF.ViewModels /// public void Copy() { - Clipboard.SetDataObject(this.ErrorMessage + Environment.NewLine + this.Details, true); + try + { + Clipboard.SetDataObject(this.ErrorMessage + Environment.NewLine + this.Details, true); + } + catch (Exception exc) + { + this.errorService.ShowError(Resources.Clipboard_Unavailable, Resources.Clipboard_Unavailable_Solution, exc); + } } } } \ No newline at end of file diff --git a/win/CS/HandBrakeWPF/ViewModels/LogViewModel.cs b/win/CS/HandBrakeWPF/ViewModels/LogViewModel.cs index 6573b1f5a..d1ed6654d 100644 --- a/win/CS/HandBrakeWPF/ViewModels/LogViewModel.cs +++ b/win/CS/HandBrakeWPF/ViewModels/LogViewModel.cs @@ -16,6 +16,8 @@ namespace HandBrakeWPF.ViewModels using Caliburn.Micro; + using HandBrakeWPF.Properties; + using HandBrakeWPF.Services.Interfaces; using HandBrakeWPF.Utilities; using HandBrakeWPF.ViewModels.Interfaces; @@ -29,6 +31,8 @@ namespace HandBrakeWPF.ViewModels /// public class LogViewModel : ViewModelBase, ILogViewModel { + private readonly IErrorService errorService; + #region Private Fields private readonly ILog logService; @@ -40,8 +44,9 @@ namespace HandBrakeWPF.ViewModels /// /// Initializes a new instance of the class. /// - public LogViewModel() + public LogViewModel(IErrorService errorService) { + this.errorService = errorService; this.logService = LogService.GetLogger(); this.Title = "Log Viewer"; } @@ -78,7 +83,14 @@ namespace HandBrakeWPF.ViewModels /// public void CopyLog() { - Clipboard.SetDataObject(this.ActivityLog, true); + try + { + Clipboard.SetDataObject(this.ActivityLog, true); + } + catch (Exception exc) + { + this.errorService.ShowError(Resources.Clipboard_Unavailable, Resources.Clipboard_Unavailable_Solution, exc); + } } ///