Prism.DryIoc.Forms Prefix Reserved

This is a prerelease version of Prism.DryIoc.Forms.
There is a newer version of this package available.
See the version list below for details.
Install-Package Prism.DryIoc.Forms -Version
dotnet add package Prism.DryIoc.Forms --version
<PackageReference Include="Prism.DryIoc.Forms" Version="" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Prism.DryIoc.Forms --version
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Prism.DryIoc.Forms,"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install Prism.DryIoc.Forms as a Cake Addin
#addin nuget:?package=Prism.DryIoc.Forms&version=

// Install Prism.DryIoc.Forms as a Cake Tool
#tool nuget:?package=Prism.DryIoc.Forms&version=
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

Use these extensions to build Xamarin.Forms applications with Prism and DryIoc.

NuGet packages (8)

Showing the top 5 NuGet packages that depend on Prism.DryIoc.Forms:

Package Downloads

[DEPRECATED] Please use Prism.Plugin.Popups instead. Prism DryIoc Plugin for Xamarin Forms to provide Popup Navigation


A collection of libraries and classes to make Xamarin, Shiny, RXUI, and Prism play beautifully together


Eltra - CANOpen based IoT Framework - SDK - Xamarin UI


This Melbourne App Development Persistence Framework plugin provides methods to perform common persistence functionality that most business apps require.


Package Description

GitHub repositories (8)

Showing the top 5 popular GitHub repositories that depend on Prism.DryIoc.Forms:

Repository Stars
Shared Element Transitions between pages in Xamarin.Forms (IOS/Android)
Samples that demonstrate how to use various Prism features with Xamarin.Forms
The Mobile.BuildTools makes it easier to develop code bases in a clean, consistent, secure, and configurable way. Determine at Build which environment your app needs to run on, and what Client Secrets it should have. Plus many more amazing features!
This provides extensibility for Prism.Forms INavigationService to handle Popup Views
Version Downloads Last updated
8.1.97 56,685 5/24/2021 114,907 10/21/2020 805 8/25/2020 1,101 5/5/2020 449,670 11/21/2019 71,748 7/24/2019 1,777 6/11/2019 868 5/6/2019 1,220 2/20/2019 912 12/4/2018 197,535 10/15/2018 1,111 9/20/2018 3,927 6/15/2018 981 5/9/2018 1,918 4/2/2018 63,125 1/22/2018 3,323 1/12/2018 1,148 12/7/2017 816 11/16/2017 9,530 10/13/2017 1,968 10/6/2017
7.0.0-pre1 904 9/22/2017 23,760 3/25/2017
6.3.0 1,106 3/25/2017
6.3.0-pre2 801 2/26/2017
6.3.0-pre1 1,066 11/2/2016
6.2.0 1,541 8/10/2016

## Prism.Core
* .NET Standard Support
* Added method to clear all errors on ErrorsContainer
* Add capability to DelegateCommand's ObservesProperty to observe properties of complex types
`ObservesProperty(() => Property.NestedProperty.NestedPoperty)`

## Prism.Forms
* Fixed #683: .NET Standard support
* Fixed #765: Deep linking within a NavigationPage results in an incorrect ContentPage Title on Android
* Fixed #1008: NavigationParameters: Not possible to specify parent type as generic parameter T
* Fixed #1024: XF: NavigationService swallowing Exceptions
* Fixed #1025: Xamarin.Forms deprecated the Device.OS property in favor of the RuntimePlatform property.
* Fixed #1027: Support macOS
* Fixed #1044: When Detail of MasterDetailPage is null, Modal Navigation is possible
* Fixed #1045: When calling NavigateAsync with NavigationPage, old page's Destroy on the stack is not called
* Fixed #1046: When calling DeepLink from Navigation Stack, the second page becomes Modal navigation
* Fixed #1054: When deep linking within NavigationPage, page order is reversed
* Fixed #1063: Master of MasterDetailPage will not be destroyed
* Fixed #1085: Error occurs if null path is specified in EventToCommandBehavior
* Fixed #1089: DebugLogger does not work in nuget-package
* Fixed #1132: Prism Forms Modularity extension methods
* Fixed #1133: IModuleCatalog AddModule returns wrong type
* Fixed #1139: Modularity Enhancements
* Fixed #1076: IActiveAware not working when ContentPage (as child of a TabbedPage) is wrapped into a NavigationPage

* deprecated OnPlatform methods
* added DeviceRuntimePlatform property - this mimics the XF API and returns a string
* added RuntimePlatform property which returns an Enum of type RuntimePlatform and wraps the XF string-based values

**Container Extensions**
* deprecated the RegisterTypeForNavigationOnPlatform signature that requires explicit platform parameters
* added new signature that accepts new IPlatform objects
Container.RegisterTypeForNavigationOnPlatform<MainPage, MainPageViewModel>("Main",
new Platform<MainPage_Android>(RuntimePlatform.Android),
new Platform<MainPage_iOS>(RuntimePlatform.iOS));

# TabbedPage Navigation Behavior Change - BREAKING
## Current Behavior (v6.3.0)
`NavigateAsync("TabbedPage/ViewA/ViewB")` will select the tab ViewA in the TabbedPage if it exists, then continue navigating.  If ViewA does not exist as a tab, then you will continue to navigate as expected.

`NavigateAsync("TabbedPage/NavigationPage/ViewA/ViewB")` would search the TabbedPage for the first instance of a tab that was a NavigationPage, then navigate within the Navigation page the remaining ViewA and ViewB pages.  This provided the ability to deep link into a tab's nested navigation page, but there was no way to opt-out of this behavior.

Also, the INavigationAware methods did not get called to all tabs meaning that you would be responsible for forwarding any parameters to all your tabs.

## New Behavior
`NavigateAsync("TabbedPage/ViewA/ViewB")` will **no longer** select any tabs, but rather continue processing the navigation as separate pages on the navigation stack.

If you wish to select a tab, you will now use a parameter called "selectedTab" to indicate which tab you would like to select.


This will navigate to the TabbedPage, selected the "MiddleTab" and continue navigating ViewA and ViewB onto the navigation stack.

For tabs that are wrapped inside a NavigationPage, you can use the "|" symbol to indicate the hierarchy.


There is a constant in the `KnownNavigationParameters` called `SelectedTab` that you can use instead of a string.


This will search each tab to see if it is a navigation page and if the first page on the stack matches "MiddleTab".  This is much more flexible than the existing behavior as before it would take the first instance of the NavigationPage found.  Now you can choose which tab exactly.

Some INavigationAware methods are now fired on all Tabs:
- OnNavigatingTo will be invoked on the TabbedPage and ALL TABS.
- OnNavigatedTo will be invoked on the TabbedPage and only the SELECTED TAB.
- OnNavigatedFrom will be invoked on the TabbedPage and only the SELECTED TAB.

**Note**: the parameter key `selectedTab` is now a reserved parameter name.  Similar to a reserved keyword in C#.  If you use this in your app as a key, you may experience undesired behavior.

**Note**: At this time there is no native support for deep linking into a Tab that is a navigation page.  Please let me know if you need this functionality.