Mvvm.Navigation.Avalonia
1.5.1
dotnet add package Mvvm.Navigation.Avalonia --version 1.5.1
NuGet\Install-Package Mvvm.Navigation.Avalonia -Version 1.5.1
<PackageReference Include="Mvvm.Navigation.Avalonia" Version="1.5.1" />
paket add Mvvm.Navigation.Avalonia --version 1.5.1
#r "nuget: Mvvm.Navigation.Avalonia, 1.5.1"
// Install Mvvm.Navigation.Avalonia as a Cake Addin #addin nuget:?package=Mvvm.Navigation.Avalonia&version=1.5.1 // Install Mvvm.Navigation.Avalonia as a Cake Tool #tool nuget:?package=Mvvm.Navigation.Avalonia&version=1.5.1
Mvvm.Navigation
Provides platform independent navigation at the MVVM level and a Source Generator that automatically binds view and view models and registers this in your DI container.
🔥Features🔥
- Uses DI to resolve your view from view model.
- Generates constructors for your views(optional).
- Generates an extension method for you with all your Views and ViewModels to register them in DI.
- Does not contain custom controls, everything happens based on the attached dependency property and does not limit the user.
- Allows forward/backward navigation like in Chrome.
- Allows you to receive activation/deactivation events - just implement IActivatableViewModel for your ViewModel.
- Allows you to generate a typed ViewModel property via an attribute, bound to your BindingContext and initialized from DI.
- Supports automatic mapping between View and ViewModel based on a global attribute.
- Allows case-by-case, attribute-based control for Views.
Usage
- Add
.AddMvvmNavigation()
call to your Host builder orIServiceCollection
:
public sealed partial class App
{
public App()
{
AppHost = Host
.CreateDefaultBuilder()
.AddMvvmNavigation()
.Build();
}
}
- Add ViewFor attribute to your views:
using Mvvm.Navigation;
[ViewFor<MainViewModel>]
public partial class MainPage : UserControl;
or assembly level attribute(nameof behavior is ignored and the full namespace is taken):
[assembly:MapViews(
viewsNamespace: nameof(MyNamespace.Views),
viewModelsNamespace: nameof(MyNamespace.ViewModels))]
or in .csproj:
<ItemGroup Label="Navigation">
<AssemblyAttribute Include="Mvvm.Navigation.MapViews">
<_Parameter1>nameof(MyNamespace.Views)</_Parameter1>
<_Parameter1_IsLiteral>true</_Parameter1_IsLiteral>
<_Parameter2>nameof(MyNamespace.ViewModels)</_Parameter2>
<_Parameter2_IsLiteral>true</_Parameter2_IsLiteral>
<ViewLifetime>Mvvm.Navigation.ServiceLifetime.Transient</ViewLifetime>
<ViewLifetime_IsLiteral>true</ViewLifetime_IsLiteral>
<ViewModelLifetime>Mvvm.Navigation.ServiceLifetime.Scoped</ViewModelLifetime>
<ViewModelLifetime_IsLiteral>true</ViewModelLifetime_IsLiteral>
</AssemblyAttribute>
</ItemGroup>
Default lifetime is ServiceLifetime.Transient
for View and ServiceLifetime.Scoped
for ViewModel.
3. Add Navigator to your ViewModel:
public Navigator<ObservableObject> Navigator { get; }
- Add commands to your views(or just use Navigator from ViewModel):
<Grid>
<Button
Command="{Binding Navigator.NavigateByTypeCommand}"
CommandParameter="{x:Type viewModels:BlueViewModel}"
/>
<ContentControl Content="{Binding Navigator.CurrentView}"/>
</Grid>
Tip: you can use CommandParameter="{mvvm:Type Type=viewModels:BlueViewModel}"
for WinUI/UWP/Uno platforms.
Base
The library was written as a replacement for ReactiveUI in a real project,
and inherits some concepts from it, excluding reactivity.
If you have the same task, then the changes are as follows:
- Replace RoutingState with Navigator
- Replace IScreen with INavigable
- Replace ReactiveUserControl with UserControl
- Replace ReactiveWindow with Window
- Replace RoutedViewHost and ViewModelViewHost with ContentControl
- Use
mvvm:Navigation.ViewModel
andmvvm:Navigation.Navigator
(includes ServiceProvider) attached dependency properties. - Or just bind like this
<ContentControl Content="{Binding Navigator.CurrentView}"/>
Support
Priority place for bugs: https://github.com/HavenDV/Mvvm.Navigation/issues
Priority place for ideas and general questions: https://github.com/HavenDV/Mvvm.Navigation/discussions
I also have a Discord support channel:
https://discord.gg/g8u2t9dKgE
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 is compatible. 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Avalonia (>= 11.0.9)
- Mvvm.Navigation.Core (>= 1.5.1)
-
net8.0
- Avalonia (>= 11.0.9)
- Mvvm.Navigation.Core (>= 1.5.1)
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 |
---|---|---|
1.5.1 | 247 | 3/5/2024 |
1.5.0 | 135 | 3/4/2024 |
1.4.5 | 257 | 12/4/2023 |
1.4.4 | 139 | 12/4/2023 |
1.4.3 | 153 | 12/4/2023 |
1.4.1 | 141 | 12/3/2023 |
1.4.0 | 143 | 12/3/2023 |
1.3.0 | 141 | 12/1/2023 |
1.2.7 | 164 | 9/22/2023 |
1.2.6 | 146 | 9/22/2023 |
1.2.5 | 152 | 9/21/2023 |
1.2.4 | 133 | 9/16/2023 |
1.2.3 | 136 | 9/16/2023 |
1.2.2 | 166 | 9/14/2023 |
1.2.1 | 167 | 9/14/2023 |
1.2.0 | 150 | 9/14/2023 |
1.1.3 | 160 | 9/11/2023 |
1.1.2 | 149 | 9/11/2023 |
1.1.1 | 136 | 9/7/2023 |
1.1.0 | 159 | 9/5/2023 |
1.0.1 | 149 | 9/4/2023 |
1.0.0 | 149 | 9/3/2023 |
0.2.0 | 148 | 9/3/2023 |
0.1.0 | 152 | 9/2/2023 |
⭐ Last 10 features:
- feat: Updated packages. 2024-03-04
- feat: Moved View resolving to Navigator. 2024-03-04
- feat: Changed default DI scopes. 2024-03-04
- feat: Enable Trimming warnings. 2024-03-04
- feat: Replaced Resolver with ServiceProvider extension. 2023-12-03
- feat: Released 1.3.0. 2023-12-01
- feat(apps): Updated Uno app. 2023-11-30
- feat: Updated to net8.0. 2023-11-08
- feat: Added BeforeInitializeComponent/AfterInitializeComponent partial methods when generating constructors. Fixed ViewModel init order. 2023-09-14
- feat: Now you can implement IActivatable for window/control and it will work. 2023-09-14
🐞 Last 10 bug fixes:
- fix: Disabled HostBuilderExtensions generation if detected framework is none. 2024-03-05
- fix: Added TryDetectFramework instead DetectFramework. 2024-03-04
- fix: Renamed mvvm:Properties to mvvm:Navigation. 2024-03-04
- fix: Fixed some warnings. 2023-12-18
- fix: Fixed problems with Uno.WinUI. 2023-12-04
- fix: Added GenerateLibraryLayout. 2023-12-04
- fix: Try to use latest DependencyPropertyGenerator. 2023-12-04
- fix: Fixed broken DependencyPropertyGenerator version. 2023-12-04
- fix: Fixed problems with Avalonia. 2023-12-04
- fix: Properties now is static class. 2023-12-04