VijayAnand.MauiTemplates
5.2.0
Prefix Reserved
See the version list below for details.
dotnet new install VijayAnand.MauiTemplates::5.2.0
Project and Item Templates for developing .NET MAUI App that runs on Android, iOS, macOS, Windows, and Tizen
- All-in-One .NET MAUI App project template and is named as
mauiapp
- .NET MAUI Class Library project template and is named as
mauiclasslib
- Shared Class Library (Xamarin.Forms and .NET MAUI) project template and is named as
sharedclasslib
Item templates for the following:
Item | Template Name |
---|---|
.NET MAUI Item (XAML) | maui-item |
.NET MAUI Item (C#) | maui-item-cs |
ContentPage (XAML) | maui-page |
ContentPage (C#) | maui-page-cs |
ContentPage (Razor) | maui-page-razor |
ContentView (XAML) | maui-view |
ContentView (C#) | maui-view-cs |
ContentView (Razor) | maui-view-razor |
ResourceDictionary (XAML) | maui-resdict |
ShellPage (XAML) | maui-shell |
ShellPage (C#) | maui-shell-cs |
ShellPage (Razor) | maui-shell-razor |
ContentPage (XAML) with ViewModel | maui-mvvm |
ContentPage (C#) with ViewModel | maui-mvvm-cs |
ContentPage with BlazorWebView (XAML) | maui-bwv |
ContentPage with BlazorWebView (C#) | maui-bwv-cs |
Partial Class (C#) | class-cs |
All of these templates currently target .NET MAUI on .NET 6/7/8 GA and its Service Releases
.
Install the template package from NuGet with the below command.
Stable:
dotnet new install VijayAnand.MauiTemplates
If you've already installed this package, then this can be updated to the latest version with the below command.
dotnet new update --check-only
dotnet new update
Parameters:
Starting with v2.0.0 of the template package, to effectively support .NET MAUI on both .NET 6
and .NET 7
, CLI project template defines a new parameter named framework
:
And from v3.0.0 of the template package, CLI project template framework
parameter adds .NET 8
as another option.
And from v4.0.0 of the template package, CLI project template defines a new parameter named language
:
And from v4.4.0 of the template package, CLI project template defines a new parameter named central-pkg-mgmt
:
And from v4.5.0 of the template package, CLI project template defines a new parameter named include-shared-toolkit
:
And from v4.6.0 of the template package, CLI project template defines a new parameter named nightly
:
And from v5.0.0 of the template package, CLI project template framework
parameter adds .NET 9
as another option.
Nightly build: (Short notation:
-ni
):Option to reference Nightly build MAUI packages (from the CI feed) in all the supported templates.
-ni
|--nightly
This is a Boolean parameter - Default value isfalse
. Can also be used with the CPM option too.Note: For this work, add the following URL as a NuGet package source and more details here:
https://aka.ms/maui-nightly/index.json
Examples:
dotnet new mauiapp -o MyApp -ni
dotnet new mauiclasslib -o MauiLib -ni
dotnet new sharedclasslib -o SharedLib -ni
Central Package Management: (Short notation:
-cpm
):This is a Boolean parameter and its default value is
false
. For now, this option is supported only on CLI.Examples:
dotnet new mauiapp -o MyApp -cpm
dotnet new mauiclasslib -o MauiLib -cpm
dotnet new sharedclasslib -o SharedLib -cpm
Language: (Short notation:
-lang
):This can take
C#
/F#
as its options (withC#
being the default value, if not specified).Examples:
dotnet new mauiapp -lang F# -f net7.0
For creating a .NET MAUI App on .NET 8:
dotnet new mauiapp -lang F#
Framework: (Short notation:
-f
)This can take
net6.0
/net7.0
/net8.0
/net9.0
as its options (withnet8.0
being the default value, if not provided).Examples:
dotnet new mauiapp -f net6.0
dotnet new mauiapp -f net7.0
For creating a .NET MAUI App on .NET 8:
Below command can be simplified to
dotnet new mauiapp
as default value offramework
parameter isnet8.0
dotnet new mauiapp -f net8.0
For creating a .NET MAUI App on .NET 9:
Explicit value for the
framework
parameter is required.dotnet new mauiapp -f net9.0
In .NET CLI, all of these Items Template require a mandatory parameter:
Name: (Short notation:
-n
)The name of the Item/Page/View to create. For Pages/Views, don't need to suffix it with the name like .xaml, it will get added.
If the name parameter is not specified, by default, the .NET CLI template engine will take the current folder name as the filename (current behaviour of the templating engine).
Now with more options while creating the app or class library project, ability to include NuGet packages on the fly for
CommunityToolkit.Maui
,CommunityToolkit.Maui.Markup
,CommunityToolkit.Mvvm
or all.
Note: Parameter values are case-insensitive.
Both .NET MAUI App and Class Library templates take the below optional Boolean parameters to include the officially supported CommunityToolkit NuGet packages:
Specifying the parameter name, either in short or full notation, implies that it is defined.
-it
|--include-toolkit
- Default isfalse
-im
|--include-markup
- Default isfalse
-imt
|--include-mvvm-toolkit
- Default isfalse
Other Parameters:
-ist
|--include-shared-toolkit
- Default isfalse
-cc
|--conditional-compilation
- Default isfalse
Conditional Compilation
And now conditional compilation can be configured so that platform source files can be defined anywhere in the project provided they follow a naming convention as mentioned below. This will allow maintaining related source files in the same place, especially MAUI Handlers.
- *.Standard.cs - Files targeting the BCL
- *.Android.cs - Files specific to Android
- *.iOS.cs - Files shared with both iOS and MacCatalyst
- *.MacCatalyst.cs - Files specific to MacCatalyst
- *.Tizen.cs - Files specific to Tizen
- *.Windows.cs - Files specific to Windows
For existing projects, add the below block of code in the project file (.csproj). This will modify the behavior of build process so due care must be taken if doing so.
<ItemGroup Condition="'$(TargetFramework)' != 'net8.0'">
<Compile Remove="**\*.Standard.cs" />
<None Include="**\*.Standard.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
</ItemGroup>
<ItemGroup Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) != 'ios' AND $([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) != 'maccatalyst'">
<Compile Remove="**\*.iOS.cs" />
<None Include="**\*.iOS.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
<Compile Remove="**\iOS\**\*.cs" />
<None Include="**\iOS\**\*.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
</ItemGroup>
<ItemGroup Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) != 'android'">
<Compile Remove="**\*.Android.cs" />
<None Include="**\*.Android.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
<Compile Remove="**\Android\**\*.cs" />
<None Include="**\Android\**\*.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
</ItemGroup>
<ItemGroup Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) != 'maccatalyst'">
<Compile Remove="**\*.MacCatalyst.cs" />
<None Include="**\*.MacCatalyst.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
<Compile Remove="**\MacCatalyst\**\*.cs" />
<None Include="**\MacCatalyst\**\*.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
</ItemGroup>
<ItemGroup Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) != 'tizen'">
<Compile Remove="**\*.Tizen.cs" />
<None Include="**\*.Tizen.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
<Compile Remove="**\Tizen\**\*.cs" />
<None Include="**\Tizen\**\*.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
</ItemGroup>
<ItemGroup Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) != 'windows'">
<Compile Remove="**\*.Windows.cs" />
<None Include="**\*.Windows.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
<Compile Remove="**\Windows\**\*.cs" />
<None Include="**\Windows\**\*.cs" Exclude="$(DefaultItemExcludes);$(DefaultExcludesInProjectFolder)" />
</ItemGroup>
All-in-One .NET MAUI App Project Template:
This takes two additional parameters to define the application design pattern and target platform respectively. Not all options are supported in the F# template. For now, only Plain and Hybrid option is available.
-dp
|--design-pattern
Can take any one of the following values, with default value set to Plain
:
Parameter Value | Description |
---|---|
Plain | App configured to work with a single, initial screen. |
Hierarchical | App configured to work in a Hierarchical pattern using NavigationPage. |
Tab | App configured to work in a Tabbed fashion using TabbedPage. |
Shell | App configured to work with Routes using Shell page. |
Hybrid | App configured to work in a Hybrid fashion using BlazorWebView. |
Markup | App configured to work with C# Markup syntax. |
Razor | App configured to work with Razor syntax. |
Comet | App configured to work with MVU pattern using Comet. |
Reactor | App configured to work with MVU pattern using Reactor. |
-tp
|--target-platform
Can take a combination of the following values, with default value set to All
:
Parameter Value | Description |
---|---|
All | Targets all possible .NET MAUI supported platforms. |
Base | Targets base framework (.NET 6/7/8) based on the framework opted. |
Android | Targets Android platform. |
iOS | Targets iOS platform. |
macOS | Targets macOS platform via Mac Catalyst. |
Windows | Targets Windows platform. |
Tizen | Targets Tizen platform. |
Mobile | Targets Android and iOS platforms. |
Desktop | Targets Windows and macOS platforms. |
Apple | Targets iOS and macOS platforms. |
Additional parameters supported:
MVVM is a delightful and development-friendly design pattern to work with. To support this, a new parameter has been introduced:
-mvvm
|--use-mvvm
- Default isfalse
-icb
|--include-compiled-bindings
- Default isfalse
Note: Opting for this MVVM option will not have any impact on the App created with Web-based Razor syntax or MVU based Comet/Reactor.
While creating a Blazor Hybrid App, an option to abstract the Razor components as a separate Razor class library.
-rcl
|--razor-class-library
- Default isfalse
The target for the Windows platform can be either Package
(MSIX) or Unpackaged
. By default, it is set as Package
, this can be overridden while creating the project by including the below parameter:
-wu
|--windows-unpackaged
- Default isfalse
While targeting .NET 7
or later, an option to add and configure CommunityToolkit.Maui.MediaElement
, Microsoft.Maui.Controls.Foldable
, Microsoft.Maui.Controls.Maps
, or all NuGet packages.
-ime
|--include-media-element
- Default isfalse
-if
|--include-foldable
- Default isfalse
-inm
|--include-maps
- Default isfalse
Note: If the project target .NET 6
, selecting the MediaElement/Foldable/Maps option will NOT have any impact.
Examples:
dotnet new mauiapp --design-pattern Hybrid --target-platform Mobile
dotnet new mauiapp -dp Shell -tp Android
.NET MAUI Class Library Project Template:
Similar to All-in-One .NET MAUI App, the Class Library project template also takes target-platform
as a parameter that takes a combination from the same set of values (with All
being the default value).
- Can be created targeting .NET Razor SDK
- Parameter name:
--use-razor-sdk
|-usr
- Parameter name:
- Can be created targeting .NET MAUI Core
- Parameter name:
--use-maui-core
|-umc
- Parameter name:
- Can be created targeting .NET MAUI Essentials
- Parameter name:
--use-maui-essentials
|-ume
- Parameter name:
Shared Class Library Project Template:
The Target Framework of Xamarin.Forms library can be defined with the the below parameter.
-xf
|--xamarin-forms
Supported values are:
netstandard2.0
(Default, if not specified)netstandard2.1
Define the Target Framework of .NET MAUI library with the -f
| --framework
parameter.
This takes the below optional Boolean parameters to include the officially supported NuGet packages:
Specifying the parameter name, either in short or full notation, implies that it is defined.
Single parameter to include all the supported NuGet packages:
-asp
|--all-supported-packages
- Default isfalse
Specific to Xamarin.Forms
:
-ife
|--include-forms-essentials
- Default isfalse
-ift
|--include-forms-toolkit
- Default isfalse
-ifm
|--include-forms-markup
- Default isfalse
Specific to .NET MAUI
:
-imt
|--include-maui-toolkit
- Default isfalse
-imm
|--include-maui-markup
- Default isfalse
Common to both:
-inmt
|--include-mvvm-toolkit
- Default isfalse
For more details: run this command in the terminal (use -h
to save some keystrokes):
dotnet new mauiapp --help
dotnet new mauiclasslib --help
dotnet new sharedclasslib --help
Partial Class Item Template:
This item template (short name: class-cs
) allows to create a C# class from CLI with support for multiple options.
Parameter Name | Type | Default Value | Remarks |
---|---|---|---|
access-modifier | choice | public | Specifies the accessibility of the class type. |
base | text | object | Specifies the base type for the class. |
abstract | bool | false | Option to create the type as abstract. |
partial | bool | true | Option to create the type as partial. |
sealed | bool | false | Option to create the type as sealed. |
static | bool | false | Option to create the type as static. |
Access Modifier parameter (--access-modifier
| -am
):
Supported values are:
- public (default value, if not provided)
- internal
- protected
- private
File-scoped Namespace parameter (-fsn
| --file-scoped-namespace
), the default value is false
.
Usage:
After installation, use the below command(s) to create new artifacts using the template (both provide the same output):
With parameter names abbreviated:
.NET MAUI App:
dotnet new mauiapp -n MyApp -dp Shell
dotnet new mauiapp -n MyApp -dp Hybrid
dotnet new mauiapp -n MyApp -dp Markup
dotnet new mauiapp -n MyApp -dp Razor
dotnet new mauiapp -n MyApp -dp Comet
dotnet new mauiapp -n MyApp -dp Reactor
Option to use MVVM:
dotnet new mauiapp -n MyApp -mvvm
dotnet new mauiapp -n MyApp -dp Markup -mvvm
Option to use MVVM (Compiled Bindings):
dotnet new mauiapp -n MyApp -mvvm -icb
Option to create Razor class library while creating Blazor Hybrid App:
dotnet new mauiapp -n MyApp -dp Hybrid -rcl
Option to include NuGet packages:
dotnet new mauiapp -n MyApp -dp Shell -it -im -imt -ime -inm -if
Option to configure conditional compilation:
dotnet new mauiapp -n MyApp -dp Shell -cc
.NET MAUI Class Library:
dotnet new mauiclasslib -n MyApp.Core
Option to include NuGet packages:
dotnet new mauiclasslib -n MyApp.Core -it -im -imt
Option to configure conditional compilation:
dotnet new mauiclasslib -n MyApp.Core -cc
Shared Class Library:
dotnet new sharedclasslib -n MyApp.UI
Option to include all supported NuGet packages:
dotnet new sharedclasslib -n MyApp.UI -asp
Generic Item Template:
- A revolutionary generic template, in XAML and C#, for creating items of any type
- And it is named as:
maui-item
andmaui-item-cs
- Both needs one required parameter,
-b
/--base
, the base type - And optionally takes another parameter,
-g
/--generic
, to specify the generic base type - In addition, XAML template takes one more parameter,
-xo
/--xaml-only
, to generate only XAML definition
Note: Namespace resolution in both XAML and C# file is left to the user as deriving them with the template is outside its scope.
dotnet new maui-item -n LoginPage -b ContentPage
dotnet new maui-item-cs -n ProductView -b ContentView
dotnet new maui-item -n CartPage -b MauiPage -g CartViewModel
For Page/Shell/View Item templates, don't suffix anything to the name, it'll be included automatically.
Pages:
dotnet new maui-page -n Home
dotnet new maui-page-cs -n Home
dotnet new maui-page-razor -n Home
Page with ViewModel:
dotnet new maui-mvvm -n Login
dotnet new maui-mvvm-cs -n Login
ContentPage with BlazorWebView:
dotnet new maui-bwv -n Home
dotnet new maui-bwv-cs -n Home
Views:
dotnet new maui-view -n Order
dotnet new maui-view-cs -n Order
dotnet new maui-view-razor -n Order
Shell:
dotnet new maui-shell -n App
dotnet new maui-shell-cs -n App
dotnet new maui-shell-razor -n App
Resource Dictionary:
dotnet new maui-resdict -n DarkTheme
dotnet new maui-resdict -n LightTheme -xo
Partial Class:
dotnet new class-cs -n BaseViewModel -b ObservableObject
dotnet new class-cs -n OrderDataStore -b IDataStore -p false -am internal
With parameter names expanded:
.NET MAUI App:
dotnet new mauiapp --name MyApp --design-pattern Shell
dotnet new mauiapp --name MyApp --design-pattern Hybrid
dotnet new mauiapp --name MyApp --design-pattern Markup
dotnet new mauiapp --name MyApp --design-pattern Razor
dotnet new mauiapp --name MyApp --design-pattern Comet
dotnet new mauiapp --name MyApp --design-pattern Reactor
Option to use MVVM:
dotnet new mauiapp --name MyApp --use-mvvm
dotnet new mauiapp --name MyApp --design-pattern Markup --use-mvvm
Option to use MVVM (Compiled Bindings):
dotnet new mauiapp --name MyApp --use-mvvm --include-compiled-bindings
Option to create Razor class library while creating Blazor Hybrid App:
dotnet new mauiapp --name MyApp --design-pattern Hybrid --razor-class-library
Option to include NuGet packages:
dotnet new mauiapp --name MyApp --design-pattern Shell --include-toolkit --include-markup --include-mvvm-toolkit --include-media-element --include-maps --include-foldable
dotnet new mauiapp --name MyApp --design-pattern Shell --conditional-compilation
.NET MAUI Class Library:
dotnet new mauiclasslib --name MyApp.Core
dotnet new mauiclasslib --name MyApp.Core --include-toolkit --include-markup --include-mvvm-toolkit
dotnet new mauiclasslib --name MyApp.Core --conditional-compilation
Shared Class Library:
dotnet new sharedclasslib --name MyApp.UI
dotnet new sharedclasslib --name MyApp.UI --all-supported-packages
Generic Item Template:
dotnet new maui-item --name LoginPage --base ContentPage
dotnet new maui-item-cs --name ProductView --base ContentView
dotnet new maui-item --name CartPage --base MauiPage --generic CartViewModel
For Page/Shell/View Item templates, don't suffix anything to the name, it'll be included automatically.
Pages:
dotnet new maui-page --name Home
dotnet new maui-page-cs --name Home
dotnet new maui-page-razor --name Home
Page with ViewModel:
dotnet new maui-mvvm --name Login
dotnet new maui-mvvm-cs --name Login
ContentPage with BlazorWebView:
dotnet new maui-bwv --name Home
dotnet new maui-bwv-cs --name Home
Views:
dotnet new maui-view --name Order
dotnet new maui-view-cs --name Order
dotnet new maui-view-razor --name Order
Shell:
dotnet new maui-shell --name App
dotnet new maui-shell-cs --name App
dotnet new maui-shell-razor --name App
Resource Dictionary:
dotnet new maui-resdict --name DarkTheme
dotnet new maui-resdict --name LightTheme --xaml-only
Partial Class:
dotnet new class-cs --name BaseViewModel
dotnet new class-cs --name OrderDataStore --base IDataStore --partial false --access-modifier internal
-
.NETStandard 2.0
- No dependencies.
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 |
---|---|---|
6.1.0 | 158 | 11/29/2024 |
6.0.0 | 74 | 11/19/2024 |
5.15.0 | 116 | 10/23/2024 |
5.14.0 | 81 | 10/10/2024 |
5.13.0 | 126 | 9/13/2024 |
5.12.1 | 115 | 8/15/2024 |
5.12.0 | 71 | 8/14/2024 |
5.11.0 | 67 | 8/5/2024 |
5.10.1 | 57 | 8/1/2024 |
5.10.0 | 75 | 7/26/2024 |
5.9.0 | 98 | 7/9/2024 |
5.8.0 | 70 | 7/5/2024 |
5.7.0 | 74 | 6/28/2024 |
5.6.2 | 87 | 6/13/2024 |
5.6.1 | 61 | 6/12/2024 |
5.6.0 | 62 | 6/11/2024 |
5.5.0 | 75 | 6/6/2024 |
5.4.0 | 242 | 5/22/2024 |
5.3.0 | 261 | 5/14/2024 |
5.2.1 | 141 | 4/17/2024 |
5.2.0 | 88 | 4/10/2024 |
5.1.0 | 408 | 3/12/2024 |
5.0.1 | 738 | 2/18/2024 |
5.0.0 | 198 | 2/14/2024 |
4.9.0 | 229 | 2/8/2024 |
4.8.1 | 614 | 1/18/2024 |
4.8.0 | 159 | 1/15/2024 |
4.7.0 | 378 | 1/4/2024 |
4.6.0 | 1,068 | 11/30/2023 |
4.5.0 | 241 | 11/24/2023 |
4.4.0 | 373 | 11/14/2023 |
4.4.0-preview.5 | 188 | 11/10/2023 |
4.4.0-preview.4 | 107 | 11/9/2023 |
4.4.0-preview.3 | 313 | 10/30/2023 |
4.4.0-preview.2 | 382 | 10/18/2023 |
4.4.0-preview.1 | 111 | 10/18/2023 |
4.3.0 | 295 | 10/13/2023 |
4.2.2 | 258 | 10/7/2023 |
4.2.1 | 188 | 10/4/2023 |
4.2.0 | 126 | 10/4/2023 |
4.1.1 | 152 | 9/26/2023 |
4.1.0 | 179 | 9/13/2023 |
4.0.1 | 178 | 8/27/2023 |
4.0.0 | 147 | 8/17/2023 |
3.6.0 | 153 | 8/10/2023 |
3.5.0 | 187 | 7/14/2023 |
3.4.1 | 199 | 6/14/2023 |
3.4.0 | 129 | 6/13/2023 |
3.3.2 | 178 | 5/18/2023 |
3.3.1 | 129 | 5/17/2023 |
3.3.0 | 133 | 5/16/2023 |
3.2.4 | 203 | 4/20/2023 |
3.2.3 | 151 | 4/17/2023 |
3.2.2 | 141 | 4/14/2023 |
3.2.1 | 142 | 4/11/2023 |
3.2.0 | 143 | 4/5/2023 |
3.2.0-preview.6 | 125 | 4/3/2023 |
3.2.0-preview.5 | 123 | 4/2/2023 |
3.2.0-preview.4 | 122 | 3/30/2023 |
3.2.0-preview.3 | 129 | 3/27/2023 |
3.2.0-preview.2 | 128 | 3/25/2023 |
3.2.0-preview.1 | 122 | 3/24/2023 |
3.1.0 | 188 | 3/23/2023 |
3.1.0-preview.9 | 120 | 3/20/2023 |
3.1.0-preview.8 | 127 | 3/18/2023 |
3.1.0-preview.7 | 126 | 3/15/2023 |
3.1.0-preview.6 | 121 | 3/14/2023 |
3.1.0-preview.5 | 123 | 3/11/2023 |
3.1.0-preview.4 | 118 | 3/9/2023 |
3.1.0-preview.3 | 126 | 3/7/2023 |
3.1.0-preview.2 | 122 | 3/4/2023 |
3.1.0-preview.1 | 123 | 3/3/2023 |
3.0.2 | 208 | 3/6/2023 |
3.0.1 | 149 | 3/3/2023 |
3.0.0 | 174 | 2/22/2023 |
2.4.1 | 158 | 2/17/2023 |
2.4.0 | 171 | 2/6/2023 |
2.3.1 | 193 | 1/27/2023 |
2.3.0 | 165 | 1/25/2023 |
2.2.0 | 197 | 12/19/2022 |
2.1.3 | 1,176 | 11/23/2022 |
2.1.2 | 376 | 11/18/2022 |
2.1.1 | 346 | 11/10/2022 |
2.1.0 | 341 | 11/8/2022 |
2.0.3 | 407 | 10/26/2022 |
2.0.2 | 406 | 10/25/2022 |
2.0.1 | 448 | 10/21/2022 |
2.0.0 | 473 | 10/4/2022 |
1.7.3 | 591 | 8/5/2022 |
1.7.2 | 624 | 6/17/2022 |
1.7.1 | 488 | 6/7/2022 |
1.7.0 | 526 | 5/24/2022 |
1.6.0 | 472 | 5/23/2022 |
1.5.0 | 529 | 5/12/2022 |
1.4.1 | 572 | 4/28/2022 |
1.4.0 | 465 | 4/27/2022 |
1.3.1 | 522 | 4/19/2022 |
1.3.0 | 513 | 4/14/2022 |
1.2.0 | 530 | 3/29/2022 |
1.1.3 | 592 | 2/19/2022 |
1.1.2 | 464 | 2/18/2022 |
1.1.1 | 475 | 2/16/2022 |
1.1.0 | 442 | 2/16/2022 |
1.0.8 | 464 | 2/14/2022 |
1.0.7 | 454 | 2/14/2022 |
1.0.6 | 476 | 2/1/2022 |
1.0.5 | 456 | 1/31/2022 |
1.0.4 | 403 | 11/9/2021 |
1.0.3 | 414 | 10/15/2021 |
1.0.2 | 1,011 | 8/16/2021 |
1.0.1 | 443 | 8/13/2021 |
1.0.0 | 382 | 8/12/2021 |
Join me on Developer Thoughts (https://egvijayanand.in/), an exclusive blog for articles on Xamarin.Forms, .NET MAUI and Blazor.
What's new in ver. 5.2.0:
-------------------------
Templates updated to support the latest .NET MAUI service release.
The .NET MAUI Community Toolkit package version bumped to reference the latest release.
v5.1.0:
Templates updated for latest .NET MAUI release.
The MauiVersion property is updated to dynamically refer to the latest available service release (8.*).
While using the CPM feature, this refers to the latest service release (8.0.10) as dynamic version is unsupported.
Auto inclusion of .NET MAUI Community Toolkit's xml namespace while using NET MAUI Generic item template with its type name defined with scope as mct:
dotnet new maui-item -n ThemePopup -b mct:Popup
v5.0.1:
Fixed the incorrect type name generation in the ContentPage with BlazorWebView item templates.
v5.0.0:
1. Support for creating .NET MAUI projects on .NET 9 Previews.
For this, have introduced an additional option to the framework parameter - net9.0
Note: The default value for the framework parameter remains as net8.0, which means to create a project for .NET 9, an explicit value of net9.0 is to be passed.
dotnet new mauiapp -o MyApp -f net9.0
2. On the stable channel, the value of the MauiVersion property is bumped to 8.0.7 to support the latest version of .NET MAUI 8 NuGet packages.
v4.9.0:
1. Better namespace resolution for item templates (support for first level folder)
2. Script automation for item templates
For more details, check this article:
https://egvijayanand.in/dotnet-maui-item-templates-made-easy-on-cli-and-visual-studio-code/
v4.8.1:
Defined MauiVersion property (with its value set to 8.0.6) in the .NET 8 stable template to support .NET MAUI 8 SR1
For more details, check this article:
https://egvijayanand.in/dotnet-maui-8-service-release-1/
v4.8.0:
1. Auto Suffix for the files created with the Page, Shell and View item templates (both XAML and C#).
dotnet new maui-page -n Settings
Output: SettingsPage.xaml and SettingsPage.xaml.cs
dotnet new maui-view-cs -n Order
Output: OrderView.cs
2. A revolutionary generic template, in XAML and C#, for creating items of any type.
And it is named as: maui-item and maui-item-cs
Both need one required parameter, -b / --base, the base type.
Optionally takes another parameter, -g / --generic, to specify the generic base type.
In addition, the XAML template takes one more parameter, -xo / --xaml-only, when defined, generates only XAML definition.
Note: Namespace resolution in both XAML and C# file is left to the user as deriving them with the template is outside its scope.
Example:
dotnet new maui-item -n HomePage -b ContentPage
Output: HomePage.xaml and HomePage.xaml.cs
public partial class HomePage : ContentPage {}
dotnet new maui-item -n SearchPage -b MauiPage -g SearchViewModel
Output: SearchPage.xaml and SearchPage.xaml.cs
public partial class SearchPage : MauiPage<SearchViewModel> {}
v4.7.0:
Auto-binding the project's RootNamespace as the namespace for newly created source files from item templates (Supported only on .NET 7 SDK or later).
Xamarin.Forms Target Framework selection in Shared Class Library project template.
Parameter name: -xf | --xamarin-forms
Supported values are netstandard2.0 (default value, if not specified) and netstandard2.1
Usage:
dotnet new sharedclasslib -o SharedLib (Defaults to netstandard2.0 for Xamarin.Forms and net8.0 for .NET MAUI)
dotnet new sharedclasslib -o SharedLib -xf netstandard2.1 -f net7.0
v4.6.0:
Option to reference Nightly build MAUI packages (from CI feed) in all of the supported templates.
-ni | --nightly (Boolean parameter - Default value is false. Can also be used with the CPM option too).
dotnet new mauiapp -o MyApp -ni
dotnet new mauiclasslib -o MauiLib -ni
dotnet new sharedclasslib -o SharedLib -ni
Note: For this work, add the following URL as a NuGet package source:
https://aka.ms/maui-nightly/index.json
v4.5.0
.NET MAUI Community Toolkit package versions bumped to their latest versions supporting the .NET 8 release.
Option to reference Shared Toolkit NuGet package in all of the templates.
--include-shared-toolkit | -ist (Boolean parameter - Default value is false.)
dotnet new mauiapp -o MyApp -ist
dotnet new mauiclasslib -o MauiLib -ist
v4.4.0:
Templates updated for .NET 8 RTM.
All preview features are now stable.
Note: For now, CPM feature is only supported on CLI.
v4.4.0-preview.5:
Another set of .NET 8 / C# 12 features (Primary Constructors).
v4.4.0-preview.4:
.NET MAUI Version on the Main page of the App.
Another set of .NET 8 / C# 12 features.
v4.4.0-preview.3:
Started incorporating .NET 8 / C# 12 features wherever possible.
v4.4.0-preview.2:
Support for the CPM option extended to Class Library projects as well.
dotnet new mauiclasslib -o MauiLib -cpm
dotnet new sharedclasslib -o SharedLib -cpm
v4.4.0-preview.1:
Introduced an option for NuGet Central Package Management in CLI project templates.
-cpm | --central-pkg-mgmt - The default value is false.
dotnet new mauiapp -o MyApp -cpm
v4.3.0
Templates updated for .NET 8 RC2.
v4.2.2:
Reliability enhancement.
v4.2.1:
Defect fix in solution file.
v4.2.0:
Support for Blazor Hybrid in F# project template. Added the design-pattern parameter for this.
This takes two options, Plain and Hybrid. The default value being Plain.
Note: RCL project in the F# template is C# based as Razor compilation is not working on F# as expected.
The first command creates a Plain app whereas the second one creates a Hybrid app.
dotnet new mauiapp -o MyApp -lang F#
dotnet new mauiapp -o HybridApp -dp Hybrid -lang F#
To create project targeting .NET 7, include the Framework parameter -f net7.0
Option for file-scoped namespace in Partial Class C# template.
Option to include reference Shared Toolkit while creating the Shared Class Library project.
.NET MAUI Community Toolkit package versions bumped to their latest versions.
v4.1.1:
Updated the .NET MAUI Class Library project file.
v4.1.0:
Templates updated for .NET 8 RC1.
Project file enhancements.
The default value for Framework parameter (--framework / -f) is now updated as net8.0
v4.0.1:
Bug fix in F# template.
v4.0.0:
.NET MAUI App F# project template with Fabulous.
Note: Default language in CLI is C#. Since not all options in C# is supported in F#, refer to Help for more details.
dotnet new mauiapp -h -lang F#
Project targeting .NET 7 (default version):
dotnet new mauiapp -o MyApp -lang F#
Project targeting .NET 8:
dotnet new mauiapp -o MyApp -f net8.0 -lang F#
v3.6.0:
Templates updated for .NET 8 Preview 7.
For broader template usage, the .NET MAUI package references are updated to use the $(MauiVersion) variable rather than a fixed version.
First community contribution from @adospace (for Reactor template changes).
v3.5.0:
Templates updated for .NET 8 Preview 6.
CommunityToolkit.Maui.Maps for the Windows platform now work on .NET 8 as well.
Opting for this will include the NuGet package and configure it in the .NET MAUI startup in MauiProgram.cs
v3.4.1:
Added support for the newly released CommunityToolkit.Maui.Maps NuGet package to support the Maps feature on the Windows platform.
Opting for this will include the NuGet package and configure it in the .NET MAUI startup in MauiProgram.cs
Update your "Bing Maps API Key" for it to work properly, visit https://www.bingmapsportal.com/ to generate one.
Note: For now, this is supported only on .NET 7. Support for .NET 8 Preview in a future release.
dotnet new mauiapp -o MyApp -inm
(or)
dotnet new mauiapp -o MyApp --include-maps
v3.4.0:
Templates updated for .NET 8 Preview 5.
Version # bumped to the latest stable for CommunityToolkit.Maui (v5.2.*), CommunityToolkit.Maui.Markup (v3.2.*), and CommunityToolkit.Maui.MediaElement (2.0.*) NuGet packages.
v3.3.2:
Made changes in the source files of Hybrid and Reactor project templates.
v3.3.1:
For library projects on .NET 8, explicit package references for Microsoft.Maui.* NuGet packages.
v3.3.0:
Templates updated for .NET 8 Preview 4.
On .NET 8, explicit package references for Microsoft.Maui.Controls and Microsoft.Maui.Controls.Compatibility NuGet packages.
Version # bumped to the latest stable for CommunityToolkit.Maui (v5.1.0) and CommunityToolkit.Mvvm (v8.2.0) NuGet packages.
v3.2.4:
Fixed the issue of _Imports.razor file getting excluded while creating a project in the Razor design pattern.
v3.2.3:
Platforms folder filtered out based on the target platform opted-in for .NET MAUI App and Class Library project.
v3.2.2:
Conditionally defined supported platforms properties based on the target platform opted-in for .NET MAUI Class Library as well.
v3.2.1:
Templates updated for .NET 8 Preview 3.
v3.2.0:
All the preview features have reached stable.
v3.2.0-preview.6:
With support for StartPath property while creating the BlazorWebView item templates on .NET 8.
Note: Restore the project before making use of the item template.
v3.2.0-preview.5:
An item template for BlazorWebView in XAML and C#.
Note: While working with .NET 7 or higher SDK, the namespace parameter in short notation needs to be passed as -p:na (i.e., it needs to be prefixed with -p:).
dotnet new maui-bwv -n HomePage -na MyApp.Views
dotnet new maui-bwv-cs -n HomePage -na MyApp.Views
On .NET 7 or later:
dotnet new maui-bwv -n HomePage -p:na MyApp.Views
dotnet new maui-bwv-cs -n HomePage -p:na MyApp.Views
v3.2.0-preview.4:
Conditionally defined supported platforms properties based on the target platform opted-in.
v3.2.0-preview.3:
1. While targeting .NET 8, the StartPath property is set to load a Razor component other than the one defined with the default route address of '/'
2. A change in the navigation menu style for better interop
v3.2.0-preview.2:
1. Fixed the issue #124 - The project node is not closed properly in the solution file while creating a Blazor Hybrid with the RCL option from CLI.
2. Stability improvements that extend the list of copy-only binary files.
v3.2.0-preview.1:
While creating a Blazor Hybrid App, an option to abstract the Razor components as a separate Razor class library.
-rcl | --razor-class-library - Default value is false
dotnet new mauiapp -n MyApp -dp Hybrid -rcl
(or)
dotnet new mauiapp --name MyApp --design-pattern Hybrid --razor-class-library
v3.1.0:
All the preview features have reached stable.
v3.1.0-preview.9:
1. Introduced an item template to generate Page and its ViewModel in a single command, available for both XAML and C#.
The Page will be generated in the Views folder and ViewModel will be generated in the ViewModels folder.
Can also be overridden to generate in the same folder with the -sf | --same-folder option.
The ViewModels are generated with the base class titled BaseViewModel (implementation left to the user).
Recommended to add CommunityToolkit.Mvvm, an officially supported NuGet package, to make it easy to work with MVVM design pattern.
Since it makes use of the .NET 7 SDK feature of auto namespace resolution, so restore the project before executing the commands.
Note: Don't suffix anything to the name, it'll be included automatically.
dotnet new maui-mvvm -n Login
dotnet new maui-mvvm-cs -n Login
Output structure:
XAML:
ViewModels
LoginViewModel.cs
Views
LoginPage.xaml
LoginPage.xaml.cs
C#:
ViewModels
LoginViewModel.cs
Views
LoginPage.cs
v3.1.0-preview.8:
1. Added the option to use Compiled Bindings option while using the MVVM option. This will make use of the x:Bind extension instead of the Binding extension.
-icb | --include-compiled-bindings - Default value is false.
dotnet new mauiapp -n MyApp -mvvm -icb
Note: When the MVVM option is not opted-in, selecting this compiled binding option will include only the NuGet package reference.
v3.1.0-preview.7:
1. Added the option to create a .NET MAUI App with the MVU pattern using Reactor.
To facilitate this, the design-pattern parameter now takes the option of Reactor.
dotnet new mauiapp -o MyApp -dp Reactor
Note: MVVM option won't have any impact on the App created with Reactor option as it is based on the MVU design pattern.
v3.1.0-preview.6:
1. Now MVVM option works with an App created with a Hybrid design pattern also.
dotnet new mauiapp -o MyApp -dp Hybrid -mvvm
2. Added the option to create a .NET MAUI App with the MVU pattern using Comet.
To facilitate this, the design-pattern parameter now takes the option of Comet.
dotnet new mauiapp -o MyApp -dp Comet
Since this Comet is still in the PoC stage and no published roadmap for future updates. So, try it at your own risk.
Note: MVVM option won't have any impact on the App created with Comet option as it is based on the MVU design pattern.
v3.1.0-preview.5:
1. MVVM is a delightful and development-friendly design pattern to work with. To support this, a new parameter has been introduced:
-mvvm | --use-mvvm and its default value is false.
XAML with MVVM:
dotnet new mauiapp -o MyApp -mvvm
C# Markup with MVVM:
dotnet new mauiapp -o MyApp -dp Markup -mvvm
To work with .NET 8 Previews: specify the framework parameter and its value: -f net8.0
Note: Opting for this MVVM option will not have any impact on the Web-based AppModels such as Blazor syntax (Hybrid) / Razor syntax.
v3.1.0-preview.4:
1. Added the option to create a .NET MAUI App using C# Markup syntax with CommunityToolkit.Maui.Markup NuGet package.
To facilitate this, the design-pattern parameter now takes the option of Markup.
dotnet new mauiapp -o MarkupApp -dp Markup
dotnet new mauiapp -o MarkupApp -f net8.0 -dp Markup
v3.1.0-preview.3:
1. Fixed the build issue (#109) of the .NET MAUI class library with .NET MAUI Essentials targeting the Windows platform.
2. Added the option to create a .NET MAUI App using Razor syntax with BlazorBindings.Maui NuGet package.
To facilitate this, the design-pattern parameter now takes the option of Razor.
dotnet new mauiapp -o BlazorBindings -dp Razor
dotnet new mauiapp -o BlazorBindings -f net8.0 -dp Razor
3. Item templates for .NET MAUI ContentPage, ContentView, and ShellPage using Razor syntax.
dotnet new maui-page-razor -n SearchPage
dotnet new maui-view-razor -n OrderView
dotnet new maui-shell-razor -n AppShell
4. Ability to set the access modifier (--access-modifier | --am) while creating a C# class from CLI.
The default value is public.
dotnet new class-cs -n Routes -am internal
v3.1.0-preview.2:
1. .NET MAUI App and Library project framework targets were restructured to better align with the development/build platforms.
This enables to make use of the template without any modification across OS such as Windows, macOS, and Linux.
2. .NET MAUI Class Library can be created target .NET MAUI Essentials.
Parameter name: --use-maui-essentials | -ume
3. While targeting .NET 8 Preview, the Tizen platform target is commented out in the project file as a public preview of the Tizen workload is yet to be made available.
This will be re-enabled once the workload is made available.
Examples:
With default values, below command creates a library project for .NET 7 with Target Platform set to All.
dotnet new mauiclasslib -o MyLib -ume
Below command creates a library project for .NET 8 with Target Platform set to Mobile (iOS and Android) and .NET 8 (Base framework).
dotnet new mauiclasslib -f net8.0 -o MyLib -ume -tp Mobile Base
v3.1.0-preview.1:
1. Similar to the All-in-One .NET MAUI App, the Class Library project template also takes target-platform as a parameter that takes a combination of the following values (with All being the default value).
All Targets all possible .NET MAUI-supported platforms.
Base Targets base framework (.NET 6/7/8) based on the framework selected.
Android Targets Android platform.
iOS Targets iOS platform.
macOS Targets macOS platform via Mac Catalyst.
Windows Targets Windows platform via WinUI 3.
Tizen Targets Tizen platform.
Mobile Targets Android and iOS platforms.
Desktop Targets Windows and macOS platforms.
Apple Targets iOS and macOS platforms.
2. .NET MAUI Class Library can be created target .NET Razor SDK.
Parameter name: --use-razor-sdk | -usr
3. .NET MAUI Class Library can be created target .NET MAUI Core.
Parameter name: --use-maui-core | -umc
Note: .NET MAUI Essentials is a transitive dependency to .NET MAUI Core.
Examples:
With default values, below command creates a library project for .NET 7 with Target Platform set to All.
dotnet new mauiclasslib -o MyLib -urs -umc
Below command creates a library project for .NET 8 with Target Platform set to Mobile (iOS and Android) and .NET 8 (Base framework).
dotnet new mauiclasslib -f net8.0 -o MyLib -urs -umc -tp Mobile Base
v3.0.2:
Fix for https://github.com/egvijayanand/dotnet-maui-templates/issues/110
v3.0.1:
1. Additional parameters added to the Partial Class (class-cs) item template.
Name Type Default Value Remarks
--------------------------------------------------------------------------
base text object Specifies the base type for the class.
abstract bool false Option to create the type as abstract.
partial bool true Option to create the type as partial.
sealed bool false Option to create the type as sealed.
static bool false Option to create the type as static.
Examples:
dotnet new class-cs -n BaseViewModel -b ObservableObject
Opting out of partial feature:
dotnet new class-cs OrderDataStore -b IDataStore -p false
2. Dependent packages have been updated to their latest versions.
v3.0.0:
Templates updated for .NET 8 Preview 1.
Supported values for target framework parameter, can be specified with --framework / -f
net6.0
net7.0 (the default value)
net8.0
Examples:
dotnet new mauiapp -f net8.0 -o MyApp
dotnet new mauiclasslib -f net8.0 -o MyLib
dotnet new sharedclasslib -f net8.0 -o MyApp.UI
v2.4.1:
1. Short name for Partial Class (C#) item template is now renamed as class-cs to avoid conflict with .NET SDK Class template (available from v7.0.200).
dotnet new class-cs -n BaseViewModel
2. While creating a .NET MAUI App, Base framework is now an option for target-platform parameter
Will be auto included when the target-platform value is set to All (the default value, if not supplied)
dotnet new mauiapp -o MyApp -tp Mobile Base
3. An item template for Shell definition in C#
dotnet new maui-shell-cs -n AppShell -p:na MyApp
v2.4.0:
1. CommunityToolkit.Maui.Markup NuGet package bumped to v3.0.0 that supports TypedBindings
2. Introduced a new item template for creating a C# class (partial) from CLI
dotnet new class -n BaseViewModel
Note:
Auto binding the project's RootNamespace as the namespace for newly created class type is supported only on .NET 7 SDK or later.
While running on earlier SDK versions, it has to be manually modified.
And due to the limitation in the templating engine, only the RootNamespace would get added, need to manually adjust for sub-folders, if any.
v2.3.1:
CommunityToolkit.Maui.MediaElement NuGet package bumped to v1.0.1 with the explicit WindowsAppSDK reference removed.
v2.3.0:
1. Ability to add reference to CommunityToolkit.Maui.MediaElement NuGet package and configure it in startup pipeline for playing audio/video in a .NET MAUI app
2. Dependent packages have been updated to reference latest stable version
CommunityToolkit.Maui - v5.0.0
CommunityToolkit.Mvvm - v8.1.0
v2.2.0:
1. Template package updated to support .NET 7 SR1 (v7.0.52).
2. Base framework is also included as a target (net6.0/net7.0) to .NET MAUI App project template when the target-platform is set to All.
3. To create a XAML-only resource dictionary template, include either --xaml-only (-xo) or --no-code-behind (-ncb) parameter.
v2.1.3:
The target-platform parameter is now updated as a multi-choice value. Can be opted-in according to the need.
And little housekeeping to improve the reliability of the templates.
v2.1.1:
1. Template package updated to support newly released .NET 7 NuGet dependencies.
2. For App project targeting .NET 7, option to add and configure Maui Foldable NuGet package.
Note: If the project target .NET 6, selecting the Foldable/Maps option will NOT have any impact.
v2.1.0:
Template package updated to support .NET 7 GA release.
v2.0.3:
1. A parameter named target-platform has been introduced that takes any one of the following values (with All being the default value).
All - Targets all possible .NET MAUI supported platforms.
Android - Targets Android platform.
iOS - Targets iOS platform.
macOS - Targets macOS platform via Mac Catalyst.
Windows - Targets Windows platform.
Tizen - Targets Tizen platform.
Mobile - Targets Android and iOS platforms.
Desktop - Targets Windows and macOS platforms.
Apple - Targets iOS and macOS platforms.
dotnet new mauiapp --target-platform Mobile
dotnet new mauiapp -tp Android
v2.0.2:
Android targetSdkVersion set in accordance with the framework version selected.
.NET 7 - targetSdkVersion 33
.NET 6 - targetSdkVersion 31
v2.0.1:
Templates have been updated to support .NET MAUI on .NET 7 (RC2 - Preview release).
v2.0.0:
1. A parameter named framework has been introduced that takes either net6.0 or net7.0 as its options (with net7.0 being the default value).
dotnet new mauiapp --framework net6.0
dotnet new mauiapp -f net7.0
2. For App project targeting .NET 7, option to add and configure Maui Maps NuGet package.
Note: If project target .NET 6, selecting the Maps option will NOT have any impact.