MessageDialogManagerLib 1.0.3
dotnet add package MessageDialogManagerLib --version 1.0.3
NuGet\Install-Package MessageDialogManagerLib -Version 1.0.3
<PackageReference Include="MessageDialogManagerLib" Version="1.0.3" />
paket add MessageDialogManagerLib --version 1.0.3
#r "nuget: MessageDialogManagerLib, 1.0.3"
// Install MessageDialogManagerLib as a Cake Addin #addin nuget:?package=MessageDialogManagerLib&version=1.0.3 // Install MessageDialogManagerLib as a Cake Tool #tool nuget:?package=MessageDialogManagerLib&version=1.0.3
MessageDialogManagerLib
MessageDialogManagerLib is a library to easily use dialogs from ViewModels in WPF Mahapps.Metro applications. This library uses Mahapps.Metro to show info, progress, ok/cancel or custom dialog. To show an open file dialog, this library uses Microsoft.Win32.OpenFileDialog, to show a save file dialog uses Microsoft.Win32.SaveFileDialog and to show a folder browser, this library uses FolderBrowserEx.
Supporting .NET Framework (4.5+) and .NET Core (3.0 and 3.1)
Introduction
In both WPF .NET Framework and .NET Core applications we can use dialogs. The problem comes when you want to show a dialog from a ViewModel, especially when you want to test your ViewModel and dialogs block your tests.
The aim of this project is to offer a library with an interface to easily inject in your ViewModel. Your ViewModel will be independent from dialogs implementations and will be testable without blocks.
Getting Started
To use this library, there are a few options:
- Download the Github repository
- Use the MessageDialogManagerLib Nuget Package
To use this library, the WPF application has to use Mahapps.Metro.
The MessageDialogManagerLib uses the IMessageDialogManager interface.
public interface IMessageDialogManager
{
/// <summary>
/// Shows a folder browser dialog
/// </summary>
/// <param name="title">Sets the title of the dialog</param>
/// <param name="initialPath">Sets the initial path of the dialog</param>
/// <returns>Returns if a folder has been selected</returns>
bool ShowFolderBrowser(string title, string initialPath, bool allowMultiSelect = false);
/// <summary>
/// Gets the selected folder
/// </summary>
string FolderPath { get; set; }
/// <summary>
/// Shows a file browser dialog
/// </summary>
/// <param name="title">Sets the title of the dialog</param>
/// <param name="initialPath">Sets the initial path of the dialog</param>
/// <param name="filter">Sets a filter to show only the files that meet the filter</param>
/// <returns>Returns if a file has been selected</returns>
bool ShowFileBrowser(string title, string initialPath, string filter, bool allowMultiSelect = false);
/// <summary>
/// Gets the selected file
/// </summary>
string FilePath { get; set; }
/// <summary>
/// Shows a save file dialog
/// </summary>
/// <param name="title">Sets the title of the dialog</param>
/// <param name="initialPath">Sets the initial path of the dialog</param>
/// <param name="fileName">Sets the file's name</param>
/// <param name="defaultExt">Sets the default file's extension</param>
/// <param name="filter">Sets the filter</param>
/// <returns>Returns if a file has been saved</returns>
bool ShowSaveFileDialog(string title, string initialPath, string fileName,
string defaultExt, string filter);
/// <summary>
/// Gets the file to save
/// </summary>
string FilePathToSave { get; set; }
/// <summary>
/// Shows a ok and cancel dialog
/// </summary>
/// <param name="text">Sets the text of the dialog</param>
/// <param name="title">Sets the title of the dialog</param>
/// MessageDialogResult.OK if the user clicks OK in the dialog box;
/// otherwise, MessageDialogResult.Cancel.
Task<MessageDialogResult> ShowOkCancelDialogAsync(string text, string title);
/// <summary>
/// Shows a info dialog
/// </summary>
/// <param name="title">Sets the title of the dialog</param>
/// <param name="message">Sets the message of the dialog</param>
/// <returns></returns>
Task ShowInfoDialogAsync(string title, string message);
/// <summary>
/// Shows a progress dialog
/// </summary>
/// <param name="title">Sets the title of the dialog</param>
/// <param name="message">Sets the message of the dialog</param>
/// <returns></returns>
Task ShowProgress(string title, string message);
/// <summary>
/// Updates the progress
/// </summary>
/// <param name="progress">Sets de progress</param>
void UpdateProgress(double progress);
/// <summary>
/// Updates the message progress
/// </summary>
/// <param name="message">Sets the message progress</param>
void UpdateMessageProgress(string message);
/// <summary>
/// Closes the progress dialog
/// </summary>
/// <returns></returns>
Task CloseProgress();
/// <summary>
/// Shows a custom dialog
/// </summary>
/// <param name="viewModel">Sets the viewmodel attached to the custom dialog</param>
/// <returns></returns>
Task ShowDialogAsync(IDialogViewModel viewModel);
}
To use MessageDialogManagerLib in an application, you can follow this example code. There are others examples in the directory Samples of the solution.
using CommandLibrary;
using MessageDialogManagerLib;
using System.Threading.Tasks;
using System.Windows.Input;
namespace NetFrameworkSample.ViewModel
{
public class MainWindowViewModel
{
private readonly IMessageDialogManager _messageDialogManager;
public MainWindowViewModel(IMessageDialogManager messageDialogManager)
{
_messageDialogManager = messageDialogManager;
ShowOkCancelDialogCommand = new Command(
ShowOkCancelDialogCommandExecute,
ShowOkCancelDialogCommandCanExecute);
}
public ICommand ShowOkCancelDialogCommand { get; private set; }
private async void ShowOkCancelDialogCommandExecute()
{
MessageDialogResult result =
await _messageDialogManager.ShowOkCancelDialogAsync(
"Ok Cancel Dialog",
"This is a Ok Cancel Dialog");
if (result == MessageDialogResult.OK)
await _messageDialogManager.ShowInfoDialogAsync("Result", "You select Ok");
else
await _messageDialogManager.ShowInfoDialogAsync("Result", "You select Cancel");
}
private bool ShowOkCancelDialogCommandCanExecute()
{
return true;
}
}
}
License
Copyright © 2020 Evaristo Cuesta
MessageDialogManagerLib is provided as-is under the MIT license. For more information see LICENSE.
Credits
This project uses Mahapps.Metro and FolderBrowserEx.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp3.0 is compatible. netcoreapp3.1 is compatible. |
.NET Framework | net452 is compatible. net46 is compatible. net461 was computed. net462 was computed. net463 was computed. net47 is compatible. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
-
.NETCoreApp 3.0
- FolderBrowserEx (>= 1.0.1)
- MahApps.Metro (>= 2.2.0)
-
.NETCoreApp 3.1
- FolderBrowserEx (>= 1.0.1)
- MahApps.Metro (>= 2.2.0)
-
.NETFramework 4.5.2
- FolderBrowserEx (>= 1.0.1)
- MahApps.Metro (>= 2.2.0)
-
.NETFramework 4.6
- FolderBrowserEx (>= 1.0.1)
- MahApps.Metro (>= 2.2.0)
-
.NETFramework 4.7
- FolderBrowserEx (>= 1.0.1)
- MahApps.Metro (>= 2.2.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.