equadrat.Framework.Mvvm.SinglePageView.Maui 6.0.8

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package equadrat.Framework.Mvvm.SinglePageView.Maui --version 6.0.8                
NuGet\Install-Package equadrat.Framework.Mvvm.SinglePageView.Maui -Version 6.0.8                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="equadrat.Framework.Mvvm.SinglePageView.Maui" Version="6.0.8" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add equadrat.Framework.Mvvm.SinglePageView.Maui --version 6.0.8                
#r "nuget: equadrat.Framework.Mvvm.SinglePageView.Maui, 6.0.8"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install equadrat.Framework.Mvvm.SinglePageView.Maui as a Cake Addin
#addin nuget:?package=equadrat.Framework.Mvvm.SinglePageView.Maui&version=6.0.8

// Install equadrat.Framework.Mvvm.SinglePageView.Maui as a Cake Tool
#tool nuget:?package=equadrat.Framework.Mvvm.SinglePageView.Maui&version=6.0.8                

equadrat Framework Mvvm

The idea of the equadrat Framework is to provide APIs to build applications with an architecture of highly decoupled components. Every single component, aspect or pattern is represented by interfaces. The framework provides a standard implementation for these but each type can be replaced by a custom implementation.

The framework is not about reimplementing components, but making them available using common interfaces.

Getting started

You can use most of the components by simply instantiating them. This is maybe the easiest way to evaluate the framework.

If you're using an IOC/DI container such as Microsoft Extensions DependencyInjection or if you want to use the built-in IOC framework, you can use the bootstrapper and bootstrapper modules to register the framework to the IOC.


The only requirement for view models is to implement INotifyPropertyChanged.

Have a look at the example applications on my website: www.equadrat.net

Interesting components

This is a list of some (not all) components of the framework which might be interesting for you.

MVVM data container & helper

  • IMvvmDataContainerFactory
  • MvvmHelper

MVVM shell

  • IMvvmShellService

MVVM views

  • IMvvmView
  • IMvvmViewFactory
  • IMvvmViewRegistry

MVVM view models

  • MvvmViewModel (optional to use)
    • Base implementation for view models
    • Event implementation
    • Creates a data container.

MVVM behaviors

  • MvvmViewModelPresenterBehavior
    • Creates the view for the assigned view model (context) of the current control.
  • MvvmViewModelProviderBehavior
    • Creates a view model and binds it to the control (context).
  • MvvmViewModelVisibilityBehavior
    • Synchronizes the view model "visibility" with the visibility of the current control.


The MVVM implementation itself is platform agnostic, but there are supporting integrations for some major client GUI frameworks.


The plan is to keep the equadrat Framework compatible to these .net versions as long as possible.

.net version min max
Core 3.1 ≥ 7.x
Standard 2.0 ≥ 2.1
Framework 4.6.2 ≥ 4.8.x

Version scheme and breaking changes

Version change Scope
Major Overhaul of the project
Minor Some types have changed
Revision Fully backward compatible
Build Set in preview versions only

Additional documentation

You can find some guides regarding specific features on my website: www.equadrat.net


You can contact me on my website: www.equadrat.net


Please respect the license and check equadrat.Framework.Mvvm.License.md before using the package.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
7.2.0 84 6/30/2024
7.1.0 84 4/20/2024
7.0.1 95 4/6/2024
7.0.0 92 4/1/2024
6.4.4 93 3/16/2024
6.4.3 97 3/9/2024
6.4.2 109 3/3/2024
6.4.1 91 2/10/2024
6.4.0 150 12/30/2023
6.3.3 176 11/15/2023
6.3.0 140 10/1/2023
6.2.0 162 8/19/2023
6.1.0 151 8/12/2023
6.0.8 150 7/22/2023

- Compatibility release.
- Upgraded Avalonia UI NuGet package references to v11.x.
- Enabled IL trimming.
- Added README.md file to the NuGet package.
- Compatibility release.
- Internal release.
- Renamed MvvmFrameworkBootstrapperModulesSelector to MvvmFrameworkBootstrapperModuleSelector.
- Initial Release