This is a very lightweight library containing base classes for implementing .NET applications using the MVVM architecture. It is fully unit tested and platform independent.
Smaragd offers base implementations of key .NET interfaces for building WPF / MVVM applications.
In addition, it enables developers to:
- Build dialog and tree structures via
DialogModel
andTreeViewModel
- Execute commands synchronously and asynchronously via
ViewModelCommand
andAsyncViewModelCommand
- Perform validation via
FuncValidation
andPredicateValidation
- Manage state updates for interdependent properties via
PropertySourceAttribute
For more information, please visit the documentation.
The recommended way to use this library is via NuGet.
Currently supported frameworks:
- .NET Standard 2.0 or higher
- .NET Framework 4.5 or higher
The following is a simple demonstration of some core features of Smaragd.
-
Choose a base class for your ViewModel.
- Inherit from
ViewModel
if you want to use the fill feature set (recommended) - Inherit from
Bindable
if you only want an implementation ofINotifyPropertyChanged
andINotifyPropertyChanging
class AppViewModel : ViewModel { // ... }
- Inherit from
-
Add a property with a backing field that invokes
PropertyChanged
when set.class AppViewModel : ViewModel { private string _name; public string Name { get => _name; set => SetProperty(ref _name, value); } }
-
Make the property dependent on the
ViewModel
'sIsDirty
property.IsDirty
indicates whether property values have changed. TheName
property then automatically updates observing views whenIsDirty
changes.class AppViewModel : ViewModel { private string _name; [PropertySource(nameof(IsDirty))] public string Name { get => IsDirty ? $"{_name} (unsaved changes)" : _name; set => SetProperty(ref _name, value); } }
-
Add an async command to reset the
IsDirty
flag.class AppViewModel : ViewModel { private string _name; [PropertySource(nameof(IsDirty))] public string Name { get => IsDirty ? $"{_name} (unsaved changes)" : _name; set => SetProperty(ref _name, value); } private IViewModelCommand<AppViewModel> _saveCommand; [IsDirtyIgnored] [IsReadOnlyIgnored] public IViewModelCommand<AppViewModel> SaveCommand => _saveCommand ??= new SaveCommand(this) } class SaveCommand : AsyncViewModelCommand<AppViewModel> { public SaveCommand(AppViewModel context) { Context = context; } protected override async Task ExecuteAsync(AppViewModel viewModel, object parameter) { // SaveChanges(viewModel); viewModel.IsDirty = false; } }
-
Create a view in XAML for your
ViewModel
and enjoy working with bindings.<Window Title="{Binding Name}"> <Button Command="{Binding SaveCommand}"> </Window>
In case you would like to see a more advanced reference application please don't hesitate to visit my other project Stein.
This library originated in my other project Stein and was subsequently moved to its own repository and nuget package. The goal is to provide a great yet minimal foundation which also promotes a good code style. Nearly everything is marked virtual (except events) so you can customize it to fit your needs.
And of course, this library is 🚀blazing fast🚀.
If you find a bug feel free to open an issue. Contributions are also appreciated.