maui-current-apis
.NET MAUI Current APIs — Guardrail Skill
This skill prevents you from generating code that uses deprecated, obsolete, or removed APIs. Read this before writing any .NET MAUI, Blazor Hybrid, or MauiReactor code.
Reasoning Framework
Follow these steps before generating any MAUI-related code:
Step 1 — Detect the Target Framework
Read the project's .csproj file and find <TargetFramework> or <TargetFrameworks>:
<!-- Single target -->
<TargetFramework>net10.0-android</TargetFramework>
<!-- Multi-target (typical MAUI project) -->
<TargetFrameworks>net10.0-android;net10.0-ios;net10.0-maccatalyst;net10.0-windows10.0.19041.0</TargetFrameworks>
The version number (net10.0, net9.0, net8.0) determines which APIs are available.
Always target the version in the project file — never assume a version.
Step 2 — Detect Library Versions
Scan <PackageReference> entries and <ItemGroup> for key packages:
| Package | What it tells you |
|---|---|
Microsoft.Maui.Controls |
MAUI version (if explicit) |
CommunityToolkit.Maui |
Toolkit version — APIs change between major versions |
CommunityToolkit.Mvvm |
MVVM Toolkit version — needed for WeakReferenceMessenger |
Reactor.Maui |
MauiReactor version — v3+ has different APIs than v2 |
Microsoft.AspNetCore.Components.WebView.Maui |
Blazor Hybrid version |
If no explicit MAUI package version is listed, the MAUI SDK version matches the <TargetFramework> .NET version.
Step 3 — Verify API Currency
Before using any API, ask yourself:
- Does this API exist in the detected version? If you're unsure, prefer the newer pattern.
- Is this a Xamarin.Forms API? MAUI is a different API surface — never assume Xamarin.Forms compatibility.
- Is this in the deprecated table below? If so, use the replacement.
- Am I using the Compatibility namespace?
Microsoft.Maui.Controls.Compatibility.*types are migration aids, not recommended for new code.
Step 4 — Apply Decision Rules
- Always use the newest form of an API when both old and new exist.
- Never generate
using Xamarin.Formsorusing Xamarin.Essentials— these are not MAUI. - Never use the
Compatibilitynamespace in new projects (Compatibility.RelativeLayout,Compatibility.StackLayout, etc.). - Prefer
asyncmethod names when both sync-named and async-named versions exist (e.g.,DisplayAlertAsyncoverDisplayAlert). - Check the project's NuGet versions before using CommunityToolkit or third-party APIs.
Deprecated API Table — .NET MAUI 10
Controls
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
ListView |
CollectionView |
ListView, EntryCell, ImageCell, SwitchCell, TextCell, ViewCell, and Cell are all deprecated in .NET 10 |
TableView |
CollectionView or custom layout |
Deprecated in .NET 10 |
Frame |
Border |
Frame is a Xamarin.Forms legacy control; Border is the MAUI replacement with StrokeShape support |
Compatibility.RelativeLayout |
Grid |
Migration-only; removed from templates in .NET 10 |
Compatibility.StackLayout |
VerticalStackLayout / HorizontalStackLayout |
The compatibility StackLayout wraps Xamarin layout logic. Use the native MAUI stack layouts for better performance |
Gestures & Input
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
ClickGestureRecognizer |
TapGestureRecognizer |
Removed in .NET 10 |
Accelerator |
KeyboardAccelerator |
Removed from Microsoft.Maui.Controls in .NET 10 |
Page & Navigation
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
Page.IsBusy |
ActivityIndicator |
IsBusy is obsolete in .NET 10; use an explicit activity indicator |
DisplayAlert() |
DisplayAlertAsync() |
Sync-named versions deprecated; use async versions |
DisplayActionSheet() |
DisplayActionSheetAsync() |
Same as above |
MessagingCenter |
WeakReferenceMessenger (CommunityToolkit.Mvvm) |
Made internal in .NET 10 |
Animation
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
FadeTo() |
FadeToAsync() |
All animation extension methods renamed to *Async in .NET 10 |
RotateTo(), ScaleTo(), TranslateTo(), etc. |
RotateToAsync(), ScaleToAsync(), TranslateToAsync(), etc. |
Same pattern — RelRotateTo → RelRotateToAsync, RelScaleTo → RelScaleToAsync, LayoutTo → LayoutToAsync |
Device & Platform APIs
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
Device.RuntimePlatform |
DeviceInfo.Platform |
The entire Device class is deprecated |
Device.BeginInvokeOnMainThread() |
MainThread.BeginInvokeOnMainThread() |
Use Microsoft.Maui.ApplicationModel.MainThread |
Device.InvokeOnMainThreadAsync() |
MainThread.InvokeOnMainThreadAsync() |
Same |
Device.OpenUri() |
Launcher.OpenAsync() |
Use Microsoft.Maui.ApplicationModel.Launcher |
Device.StartTimer() |
Dispatcher.StartTimer() or PeriodicTimer |
Use the dispatcher or standard .NET timer |
DependencyService |
Constructor injection via IServiceProvider |
Register services in MauiProgram.cs with builder.Services |
XAML & Markup
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
FontImageExtension (XAML markup extension) |
FontImageSource (type) |
Use <FontImageSource> element or property syntax |
Color.FromHex() |
Color.FromArgb() |
FromHex is obsolete |
Safe Area & Layout
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
Page.UseSafeArea (iOS platform-specific) |
SafeAreaEdges property |
New in .NET 10; ContentPage defaults to None (edge-to-edge) on all platforms |
Layout.IgnoreSafeArea |
SafeAreaEdges property |
Use the unified safe area API |
Accessibility
| ❌ Deprecated / Removed | ✅ Use Instead | Notes |
|---|---|---|
AutomationProperties.Name |
SemanticProperties.Description |
AutomationProperties still works but SemanticProperties is the MAUI-native approach |
AutomationProperties.HelpText |
SemanticProperties.Hint |
Same |
iOS SetAccessibilityHint / SetAccessibilityLabel (Compatibility extensions) |
Microsoft.Maui.Platform.UpdateSemantics() |
Deprecated in .NET 10 |
NuGet Packages
| ❌ Deprecated Package | ✅ Use Instead | Notes |
|---|---|---|
Xamarin.Forms |
Microsoft.Maui.Controls |
Completely different API surface |
Xamarin.Essentials |
Built-in MAUI APIs (Microsoft.Maui.Devices, Microsoft.Maui.ApplicationModel, etc.) |
Essentials is merged into MAUI |
Xamarin.CommunityToolkit |
CommunityToolkit.Maui |
Different namespace and API surface |
Microsoft.Toolkit.Mvvm |
CommunityToolkit.Mvvm |
Package was renamed |
MauiReactor-Specific Guidance
MauiReactor v3+ (for .NET MAUI 9/10):
- Hot reload: v3+ uses a feature switch in
.csprojvia<RuntimeHostConfigurationOption>. Do NOT use the v2EnableMauiReactorHotReload()call inMauiProgram.cs. - API wrappers: MauiReactor auto-generates C# wrappers around MAUI controls. When a MAUI control is deprecated (e.g.,
ListView), the MauiReactor wrapper is also effectively deprecated. Use the MauiReactor wrapper for the replacement control (e.g.,CollectionView). - State management: Use
State<T>andProps<T>— not olderRxComponentpatterns if they appear in outdated examples. - Navigation: Use MauiReactor's built-in navigation (
Navigation.PushAsync<PageComponent>()) — do NOT mix in MAUI ShellGoToAsyncunless deliberately integrating Shell.
Blazor Hybrid-Specific Guidance
- Use
BlazorWebView— not the legacyWebView— for hosting Razor components. - Use .NET 10 Razor syntax:
@rendermodedirectives,[SupplyParameterFromQuery], and the latest component model. - JS interop: Use
IJSRuntime.InvokeAsync<T>()— not the obsolete synchronousIJSInProcessRuntimepatterns for mobile. - Safe areas: In Blazor Hybrid, use CSS
env(safe-area-inset-*)— do NOT combine XAMLSafeAreaEdgesand CSS safe area padding on the same element (causes double-padding). - Web resource interception: .NET 10 adds
WebResourceRequestedevent onBlazorWebViewandHybridWebViewfor intercepting requests.
Version Detection Cheat Sheet
Reading the TFM
| TFM Pattern | .NET Version |
|---|---|
net10.0-* |
.NET 10 (latest, current) |
net9.0-* |
.NET 9 |
net8.0-* |
.NET 8 (LTS) |
Reading MAUI SDK Version
If the .csproj uses <UseMaui>true</UseMaui>, the MAUI version matches the TFM:
net10.0→ MAUI 10net9.0→ MAUI 9
Reading MauiReactor Version
Check <PackageReference Include="Reactor.Maui" Version="X.Y.Z" />:
- v3.x → .NET MAUI 9/10 compatible, uses feature-switch hot reload
- v2.x → Legacy, uses
EnableMauiReactorHotReload()builder pattern
Reading CommunityToolkit Version
Check <PackageReference Include="CommunityToolkit.Maui" Version="X.Y.Z" />:
- v11+ → .NET 10 compatible
- v9-10 → .NET 9 compatible
- v5-7 → .NET 8 compatible
Quick Rules
- Read the
.csprojfirst. Never generate code without knowing the target framework. - When in doubt, use the newer API. If two ways exist to do something, the newer way is correct.
- Never use
Xamarin.*namespaces. They do not exist in MAUI. - Never use
Compatibility.*types in new projects. They are migration aids only. - Check this table before using any
Device.*API. TheDeviceclass is fully deprecated. - Use
*Asyncmethod names for animations, alerts, and action sheets in .NET 10+. - Verify third-party package versions before using their APIs — CommunityToolkit, MauiReactor, and others break between major versions.