diff --git a/README.md b/README.md index 3d72c1b..e57a25a 100644 --- a/README.md +++ b/README.md @@ -107,6 +107,7 @@ ContentView | maui-view | Item ContentView (C#) | maui-view-cs | Item ResourceDictionary | maui-resdict | Item ShellPage | maui-shell | Item +Partial Class | class | Item ![All-in-One .NET MAUI App Project Template](images/dotnetmaui-all-in-one-project-template-pinned.png) @@ -371,6 +372,11 @@ Resource Dictionary: dotnet new maui-resdict -n LightTheme -na MyApp.Themes ``` +Partial Class: +```shell +dotnet new class -n BaseViewModel +``` + With parameter names expanded: .NET MAUI App: @@ -429,6 +435,11 @@ Resource Dictionary: ```shell dotnet new maui-resdict --name LightTheme --namespace MyApp.Themes ``` + +Partial Class: +```shell +dotnet new class --name BaseViewModel +``` - + diff --git a/src/MauiTemplatesCLI/MauiClassLib/MauiClassLib.1.csproj b/src/MauiTemplatesCLI/MauiClassLib/MauiClassLib.1.csproj index b888e9e..32a7d8b 100644 --- a/src/MauiTemplatesCLI/MauiClassLib/MauiClassLib.1.csproj +++ b/src/MauiTemplatesCLI/MauiClassLib/MauiClassLib.1.csproj @@ -40,7 +40,7 @@ - + diff --git a/src/MauiTemplatesCLI/MyClass/.template.config/dotnetcli.host.json b/src/MauiTemplatesCLI/MyClass/.template.config/dotnetcli.host.json new file mode 100644 index 0000000..8c438fd --- /dev/null +++ b/src/MauiTemplatesCLI/MyClass/.template.config/dotnetcli.host.json @@ -0,0 +1,8 @@ +{ + "$schema": "http://json.schemastore.org/dotnetcli.host", + "symbolInfo": { + "namespace": { + "shortName": "na" + } + } +} diff --git a/src/MauiTemplatesCLI/MyClass/.template.config/ide.host.json b/src/MauiTemplatesCLI/MyClass/.template.config/ide.host.json new file mode 100644 index 0000000..348ae09 --- /dev/null +++ b/src/MauiTemplatesCLI/MyClass/.template.config/ide.host.json @@ -0,0 +1,3 @@ +{ + "$schema": "http://json.schemastore.org/vs-2017.3.host" +} diff --git a/src/MauiTemplatesCLI/MyClass/.template.config/template.json b/src/MauiTemplatesCLI/MyClass/.template.config/template.json new file mode 100644 index 0000000..b24daed --- /dev/null +++ b/src/MauiTemplatesCLI/MyClass/.template.config/template.json @@ -0,0 +1,43 @@ +{ + "$schema": "https://json.schemastore.org/template", + "author": "Vijay Anand E G", + "defaultName": "Class1", + "classifications": [ + "Code" + ], + "identity": "VijayAnand.MyClass", + "groupIdentity": "VijayAnand.MauiTemplates.Class.Code", + "description": "An item template for Partial Class in C#", + "name": "Partial Class", + "shortName": "class", + "sourceName": "MyClass.1", + "primaryOutputs": [ + { + "path": "MyClass.1.cs" + } + ], + "tags": { + "language": "C#", + "type": "item" + }, + "symbols": { + "namespace": { + "type": "bind", + "binding": "msbuild:RootNamespace", + "replaces": "MyApp.Namespace", + "defaultValue": "MyApp.Namespace" + } + }, + "constraints": { + "dotnet7-sts": { + "type": "sdk-version", + "args": [ + "[7.0,)" + ] + }, + "csharp-only": { + "type": "project-capability", + "args": "CSharp" + } + } +} diff --git a/src/MauiTemplatesCLI/MyClass/MyClass.1.cs b/src/MauiTemplatesCLI/MyClass/MyClass.1.cs new file mode 100644 index 0000000..8cd2770 --- /dev/null +++ b/src/MauiTemplatesCLI/MyClass/MyClass.1.cs @@ -0,0 +1,10 @@ +namespace MyApp.Namespace +{ + public partial class MyClass__1 + { + public MyClass__1() + { + + } + } +} diff --git a/src/MauiTemplatesCLI/PackageVersion.txt b/src/MauiTemplatesCLI/PackageVersion.txt index 2bf1c1c..197c4d5 100644 --- a/src/MauiTemplatesCLI/PackageVersion.txt +++ b/src/MauiTemplatesCLI/PackageVersion.txt @@ -1 +1 @@ -2.3.1 +2.4.0 diff --git a/src/MauiTemplatesCLI/SharedClassLib/SharedClassLib.1.csproj b/src/MauiTemplatesCLI/SharedClassLib/SharedClassLib.1.csproj index 6938a9b..5bd7fe0 100644 --- a/src/MauiTemplatesCLI/SharedClassLib/SharedClassLib.1.csproj +++ b/src/MauiTemplatesCLI/SharedClassLib/SharedClassLib.1.csproj @@ -56,7 +56,7 @@ - + diff --git a/src/MauiTemplatesCLI/VijayAnand.MauiTemplates.csproj b/src/MauiTemplatesCLI/VijayAnand.MauiTemplates.csproj index c4a35d3..10c7551 100644 --- a/src/MauiTemplatesCLI/VijayAnand.MauiTemplates.csproj +++ b/src/MauiTemplatesCLI/VijayAnand.MauiTemplates.csproj @@ -28,7 +28,7 @@ true - diff --git a/src/MauiTemplatesCLI/overview.md b/src/MauiTemplatesCLI/overview.md index a548d91..94ef67d 100644 --- a/src/MauiTemplatesCLI/overview.md +++ b/src/MauiTemplatesCLI/overview.md @@ -14,8 +14,9 @@ Item templates for the following: |ContentView (C#)|maui-view-cs| |ResourceDictionary (XAML)|maui-resdict| |Shell (XAML)|maui-shell| +|Partial Class (C#)|class| -All of these templates currently target `.NET MAUI on .NET 7 GA`, stable release as of Nov 2022. +All of these templates currently target `.NET MAUI on .NET 6/7 GA and its Service Releases`. Install the template package from NuGet with the below command. @@ -85,12 +86,13 @@ The target for the Windows platform can be either `Package` (MSIX) or `Unpackage * `-wu` | `--windows-unpackaged` - Default is `false` -While targeting `.NET 7`, an option to add and configure `Microsoft.Maui.Controls.Foldable`, `Microsoft.Maui.Controls.Maps`, or both NuGet packages. +While targeting `.NET 7`, 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 is `false` * `-if` | `--include-foldable` - Default is `false` * `-inm` | `--include-maps` - Default is `false` -*Note: If the project target `.NET 6`, selecting the Foldable/Maps option will NOT have any impact.* +*Note: If the project target `.NET 6`, selecting the MediaElement/Foldable/Maps option will NOT have any impact.* ##### Conditional Compilation @@ -163,7 +165,7 @@ Can take any one of the following values, with default value set to `Plain`: * `-tp` | `--target-platform` -Can take any one of the following values, with default value set to `All`: +Can take a combination of the following values, with default value set to `All`: |Parameter Value|Description| |:---:|:---| @@ -235,7 +237,7 @@ dotnet new mauiapp -n MyApp -dp Hybrid ``` Option to include NuGet packages: ```shell -dotnet new mauiapp -n MyApp -dp Shell -it -im -imt -inm -if +dotnet new mauiapp -n MyApp -dp Shell -it -im -imt -ime -inm -if ``` Option to configure conditional compilation: ```shell @@ -290,6 +292,11 @@ Resource Dictionary: dotnet new maui-resdict -n LightTheme -na MyApp.Themes ``` +Partial Class: +```shell +dotnet new class -n BaseViewModel +``` + With parameter names expanded: .NET MAUI App: @@ -298,7 +305,7 @@ dotnet new mauiapp --name MyApp --design-pattern Hybrid ``` Option to include NuGet packages: ```shell -dotnet new mauiapp --name MyApp --design-pattern Shell --include-toolkit --include-markup --include-mvvm-toolkit --include-maps --include-foldable +dotnet new mauiapp --name MyApp --design-pattern Shell --include-toolkit --include-markup --include-mvvm-toolkit --include-media-element --include-maps --include-foldable ``` ```shell dotnet new mauiapp -n MyApp --design-pattern Shell --conditional-compilation @@ -348,3 +355,8 @@ Resource Dictionary: ```shell dotnet new maui-resdict --name LightTheme --namespace MyApp.Themes ``` + +Partial Class: +```shell +dotnet new class --name BaseViewModel +``` diff --git a/src/MauiTemplatesCLI/release-notes.txt b/src/MauiTemplatesCLI/release-notes.txt index 8721438..bc4b309 100644 --- a/src/MauiTemplatesCLI/release-notes.txt +++ b/src/MauiTemplatesCLI/release-notes.txt @@ -1,5 +1,21 @@ -What's new in ver. 2.3.1: +What's new in ver. 2.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: