ServerDrivenUI.Maui 8.0.66-pre

This is a prerelease version of ServerDrivenUI.Maui.
dotnet add package ServerDrivenUI.Maui --version 8.0.66-pre
                    
NuGet\Install-Package ServerDrivenUI.Maui -Version 8.0.66-pre
                    
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="ServerDrivenUI.Maui" Version="8.0.66-pre" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="ServerDrivenUI.Maui" Version="8.0.66-pre" />
                    
Directory.Packages.props
<PackageReference Include="ServerDrivenUI.Maui" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add ServerDrivenUI.Maui --version 8.0.66-pre
                    
#r "nuget: ServerDrivenUI.Maui, 8.0.66-pre"
                    
#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.
#addin nuget:?package=ServerDrivenUI.Maui&version=8.0.66-pre&prerelease
                    
Install ServerDrivenUI.Maui as a Cake Addin
#tool nuget:?package=ServerDrivenUI.Maui&version=8.0.66-pre&prerelease
                    
Install ServerDrivenUI.Maui as a Cake Tool

Maui.ServerDrivenUI

Server Driven UI library for dotnet MAUI. New features to be deployed on all platforms simultaneously via a backend change, without releasing new versions of the native apps.

NuGet

Build and publish packages

Sample Api Response: https://serverdrivenui.azurewebsites.net/ServerDrivenUI?key=MyView

Getting started

  • Install the ServerDrivenUI.Maui package
Install-Package ServerDrivenUI.Maui -Version 8.0.31-pre
  • Add UseServerDrivenUI declaration to your MauiAppBuilder and configure it to connect to your API
public static class MauiProgram
{
	public static MauiApp CreateMauiApp()
	{
            var builder = MauiApp.CreateBuilder();
            builder
            .UseMauiApp<App>()
            .ConfigureFonts(fonts =>
            {
                fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular");
                fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold");
            })
            .ConfigureServerDrivenUI(s =>
            {
                s.RegisterElementGetter((key, provider) => provider.GetService<IYourApiService>().YourApiMethod(key)); //Register which api will be used to get the UI

                s.AddServerElement("MyView"); // Register the visual elements that will follow server driven ui
            });

		return builder.Build();
	}
}
  • You can now use the ServerDrivenUI Elements, defining the key that will be used to get the UI from the API
  • You can also define a LoadingTemplate and an ErrorTemplate to be shown while the UI is being fetched from the API
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage
    x:Class="Maui.ServerDrivenUI.Sample.MainPage"
    xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
    xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml">

    <ServerDrivenView x:Name="sduiView" ServerKey="MyView">
        <ServerDrivenView.ErrorTemplate>
            <DataTemplate>
                <StackLayout>
                    <Label Text="Unexpected error" />
                </StackLayout>
            </DataTemplate>
        </ServerDrivenView.ErrorTemplate>

        <ServerDrivenView.LoadingTemplate>
            <DataTemplate>
                <StackLayout>
                    <Label Text="Loading..." />
                </StackLayout>
            </DataTemplate>
        </ServerDrivenView.LoadingTemplate>
    </ServerDrivenView>

</ContentPage>

IOS

We need to set the interpreter to allow the Xaml loader to work

  <PropertyGroup Condition="$(TargetFramework.Contains('-ios'))">
    <UseInterpreter>true</UseInterpreter>
    <MtouchInterpreter>-all</MtouchInterpreter>
  </PropertyGroup>

Know issues

MAUI 16809 - Label().LoadFromXaml does not work when using Label.FormattedText

We are currently doing a workaround to make FormattedText work with ServerDrivenUI

Repo Activity

Alt

Product Compatible and additional computed target framework versions.
.NET net8.0-android34.0 is compatible.  net8.0-ios17.0 is compatible.  net8.0-maccatalyst18.0 is compatible.  net8.0-windows10.0.19041 is compatible.  net9.0-android was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-windows was computed.  net10.0-android was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.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
8.0.66-pre 67 12/23/2024
8.0.64-pre 62 11/26/2024
8.0.62-pre 68 11/26/2024
8.0.60-pre 65 11/12/2024
8.0.59-pre 61 11/4/2024
8.0.57-pre 61 11/4/2024
8.0.56-pre 80 11/4/2024
8.0.55-pre 60 11/4/2024
8.0.54-pre 70 11/2/2024
8.0.53-pre 64 11/2/2024
8.0.52-pre 60 11/2/2024
8.0.51-pre 66 11/2/2024
8.0.50-pre 67 11/1/2024
8.0.49-pre 60 11/1/2024
8.0.48-pre 70 10/17/2024
8.0.47-pre 70 10/17/2024
8.0.46-pre 58 10/17/2024
8.0.45-pre 77 10/17/2024
8.0.41-pre 90 3/5/2024
8.0.40-pre 71 3/3/2024
8.0.37-pre 143 2/24/2024
8.0.31-pre 101 2/18/2024