Skip to content

A .NET MAUI plugin that provides helpers to make your transition from Xamarin.Forms to .NET MAUI easier

License

Notifications You must be signed in to change notification settings

jfversluis/Plugin.Maui.FormsMigration

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Plugin.Maui.FormsMigration

Plugin.Maui.FormsMigration provides helpers to make your transition from Xamarin.Forms to .NET MAUI easier.

Install Plugin

NuGet

Available on NuGet.

Install with the dotnet CLI: dotnet add package Plugin.Maui.FormsMigration, or through the NuGet Package Manager in Visual Studio.

Supported Platforms

The supported platforms for this library are Android, iOS and Windows.

API Usage

This library consists of three APIs that you can use for different scenarios:

Each of these APIs will have their own way of using it. You can find the specifics below, or have a look at the sample application that is included in this repository.

Note

These APIs are meant for transition scenarios only. Use these APIs to retrieve data that is previously stored by your legacy Xamarin application and save them in a place where .NET MAUI can access that data from that point on. This is also the reason that these APIs are read-only.

App Properties

With Xamarin and Xamarin.Forms you had the possibility to save simple types through the Properties API like so: Application.Current.Properties ["id"] = someClass.ID;. In .NET MAUI, this is no longer possible.

To help you transition from Xamarin to .NET MAUI, this library offers the LegacyApplication API to still be able to access previously saved properties. From there, save them through a newer API that is available in .NET MAUI. An example could be to use the Preferences API. See a simple example below.

int id;
if (LegacyApplication.Current.Properties.ContainsKey("id"))
{
    id = (int)LegacyApplication.Current.Properties["id"];
    Preferences.Set("id", id);
}

Note

For this API to work properly, you will have to make sure that the application identifier (or bundle identifier) is the same between your legacy Xamarin app and .NET MAUI app. This is needed so that the app gets installed in the same container on the operating system, which is needed to be able to read the property values that were stored previously.

Also see this Microsoft Learn Docs page for more information.

SecureStorage

The SecureStorage API is still available in .NET MAUI the same as it is in Xamarin and Xamarin.Forms. However, the name of the store where values were stored and some other details have changed which causes the .NET MAUI version of your app to not being able to retrieve the previously saved secure storage information.

With the LegacySecureStorage you can retrieve the previously saved information in the secure storage of your legacy Xamarin application. From there you should resave them through the .NET MAUI secure storage API. An example of how to use this API can be found below.

// The code below assumes that there is a secure value saved with the key "oauth_token". Replace this key
// with any value(s) you have stored in your legacy Xamarin app to get them out.

string oauthToken = await LegacySecureStorage.GetAsync("oauth_token");
bool result = LegacySecureStorage.Remove("oauth_token");
await SecureStorage.SetAsync("oauth_token", oauthToken);

Note

For this API to work properly, you will have to make sure that the application identifier (or bundle identifier) is the same between your legacy Xamarin app and .NET MAUI app. This is needed so that the app gets installed in the same container on the operating system, which is needed to be able to read the secure store values that were stored previously.

Warning

For iOS, make sure you have a Entitlements.plist with the following entry:

<key>keychain-access-groups</key>

<string>$(AppIdentifierPrefix)$(CFBundleIdentifier)</string>

$(AppIdentifierPrefix)$(CFBundleIdentifier) can stay in place and will be replaced at build time or you can replace it with a hardcoded value. Additionally make sure that the Entitlements.plist file is set in the Custom Entitlements field for Bundle Signing. For more information, refer to the Microsoft Learn Docs page about entitlements.

Also see this Microsoft Learn Docs page for more information.

VersionTracking

The VersionTracking API is still available in .NET MAUI the same as it is in Xamarin and Xamarin.Forms. However, the name of the store where values were stored and some other details have changed which causes the .NET MAUI version of your app to not being able to retrieve the previously saved version tracking information.

Note

For this API to work properly, you will have to make sure that the application identifier (or bundle identifier) is the same between your legacy Xamarin app and .NET MAUI app. This is needed so that the app gets installed in the same container on the operating system, which is needed to be able to read the version information that was stored previously.

Warning

Make sure that the app version of your .NET MAUI app is higher than your legacy Xamarin application. Failing to do so might have unexpected results.

Also see this Microsoft Learn Docs page for more information.

Acknowledgements

This project could not have came to be without these projects and people, thank you! <3

The code in the plugin is mostly based on the original code in Xamarin.Forms and Xamarin.Essentials. It has been adapted for the Microsoft Learn Docs by David Britch.

About

A .NET MAUI plugin that provides helpers to make your transition from Xamarin.Forms to .NET MAUI easier

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project

 

Packages

No packages published

Languages