diff --git a/SyncfusionThemeSample/SyncfusionThemeSample.sln b/SyncfusionThemeSample/SyncfusionThemeSample.sln new file mode 100644 index 0000000..6e881c5 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample.sln @@ -0,0 +1,27 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.9.34723.18 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SyncfusionThemeSample", "SyncfusionThemeSample\SyncfusionThemeSample.csproj", "{40261A07-FBB5-441B-B006-24445026C9AB}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {40261A07-FBB5-441B-B006-24445026C9AB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {40261A07-FBB5-441B-B006-24445026C9AB}.Debug|Any CPU.Build.0 = Debug|Any CPU + {40261A07-FBB5-441B-B006-24445026C9AB}.Debug|Any CPU.Deploy.0 = Debug|Any CPU + {40261A07-FBB5-441B-B006-24445026C9AB}.Release|Any CPU.ActiveCfg = Release|Any CPU + {40261A07-FBB5-441B-B006-24445026C9AB}.Release|Any CPU.Build.0 = Release|Any CPU + {40261A07-FBB5-441B-B006-24445026C9AB}.Release|Any CPU.Deploy.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {4D8E039E-B34C-425F-B1B5-BDC184F94BB5} + EndGlobalSection +EndGlobal diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/App.xaml b/SyncfusionThemeSample/SyncfusionThemeSample/App.xaml new file mode 100644 index 0000000..a184446 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/App.xaml @@ -0,0 +1,16 @@ + + + + + + + + + + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/App.xaml.cs b/SyncfusionThemeSample/SyncfusionThemeSample/App.xaml.cs new file mode 100644 index 0000000..1691ce5 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/App.xaml.cs @@ -0,0 +1,12 @@ +namespace SyncfusionThemeSample +{ + public partial class App : Application + { + public App() + { + InitializeComponent(); + + MainPage = new AppShell(); + } + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/AppShell.xaml b/SyncfusionThemeSample/SyncfusionThemeSample/AppShell.xaml new file mode 100644 index 0000000..399f34e --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/AppShell.xaml @@ -0,0 +1,15 @@ + + + + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/AppShell.xaml.cs b/SyncfusionThemeSample/SyncfusionThemeSample/AppShell.xaml.cs new file mode 100644 index 0000000..d5626d7 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/AppShell.xaml.cs @@ -0,0 +1,10 @@ +namespace SyncfusionThemeSample +{ + public partial class AppShell : Shell + { + public AppShell() + { + InitializeComponent(); + } + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/MainPage.xaml b/SyncfusionThemeSample/SyncfusionThemeSample/MainPage.xaml new file mode 100644 index 0000000..0076ab0 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/MainPage.xaml @@ -0,0 +1,14 @@ + + + + + + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/MainPage.xaml.cs b/SyncfusionThemeSample/SyncfusionThemeSample/MainPage.xaml.cs new file mode 100644 index 0000000..8af9385 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/MainPage.xaml.cs @@ -0,0 +1,34 @@ +using Syncfusion.Maui.Themes; + +namespace SyncfusionThemeSample +{ + public partial class MainPage : ContentPage + { + public MainPage() + { + InitializeComponent(); + } + private void ChangeSyncfusionControlsTheme(object sender, EventArgs e) + { + ICollection mergedDictionaries = Application.Current.Resources.MergedDictionaries; + if (mergedDictionaries != null) + { + var theme = mergedDictionaries.OfType().FirstOrDefault(); + if (theme != null) + { + if (theme.VisualTheme is SfVisuals.MaterialDark) + { + theme.VisualTheme = SfVisuals.MaterialLight; + Application.Current.UserAppTheme = AppTheme.Light; + } + else + { + theme.VisualTheme = SfVisuals.MaterialDark; + Application.Current.UserAppTheme = AppTheme.Dark; + } + } + } + } + } + +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/MauiProgram.cs b/SyncfusionThemeSample/SyncfusionThemeSample/MauiProgram.cs new file mode 100644 index 0000000..afc30e3 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/MauiProgram.cs @@ -0,0 +1,27 @@ +using Syncfusion.Maui.Core.Hosting; +using Microsoft.Extensions.Logging; + +namespace SyncfusionThemeSample +{ + public static class MauiProgram + { + public static MauiApp CreateMauiApp() + { + var builder = MauiApp.CreateBuilder(); + builder + .UseMauiApp() + .ConfigureSyncfusionCore() + .ConfigureFonts(fonts => + { + fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular"); + fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold"); + }); + +#if DEBUG + builder.Logging.AddDebug(); +#endif + + return builder.Build(); + } + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/AndroidManifest.xml b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/AndroidManifest.xml new file mode 100644 index 0000000..e9937ad --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/AndroidManifest.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/MainActivity.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/MainActivity.cs new file mode 100644 index 0000000..3986538 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/MainActivity.cs @@ -0,0 +1,11 @@ +using Android.App; +using Android.Content.PM; +using Android.OS; + +namespace SyncfusionThemeSample +{ + [Activity(Theme = "@style/Maui.SplashTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation | ConfigChanges.UiMode | ConfigChanges.ScreenLayout | ConfigChanges.SmallestScreenSize | ConfigChanges.Density)] + public class MainActivity : MauiAppCompatActivity + { + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/MainApplication.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/MainApplication.cs new file mode 100644 index 0000000..fd99d7c --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/MainApplication.cs @@ -0,0 +1,16 @@ +using Android.App; +using Android.Runtime; + +namespace SyncfusionThemeSample +{ + [Application] + public class MainApplication : MauiApplication + { + public MainApplication(IntPtr handle, JniHandleOwnership ownership) + : base(handle, ownership) + { + } + + protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp(); + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/Resources/values/colors.xml b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/Resources/values/colors.xml new file mode 100644 index 0000000..c04d749 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Android/Resources/values/colors.xml @@ -0,0 +1,6 @@ + + + #512BD4 + #2B0B98 + #2B0B98 + \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/AppDelegate.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/AppDelegate.cs new file mode 100644 index 0000000..4e42f93 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/AppDelegate.cs @@ -0,0 +1,10 @@ +using Foundation; + +namespace SyncfusionThemeSample +{ + [Register("AppDelegate")] + public class AppDelegate : MauiUIApplicationDelegate + { + protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp(); + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Entitlements.plist b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Entitlements.plist new file mode 100644 index 0000000..de4adc9 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Entitlements.plist @@ -0,0 +1,14 @@ + + + + + + + com.apple.security.app-sandbox + + + com.apple.security.network.client + + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Info.plist b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Info.plist new file mode 100644 index 0000000..7268977 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Info.plist @@ -0,0 +1,38 @@ + + + + + + + + + + + + + + UIDeviceFamily + + 2 + + UIRequiredDeviceCapabilities + + arm64 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + XSAppIconAssets + Assets.xcassets/appicon.appiconset + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Program.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Program.cs new file mode 100644 index 0000000..e7cb01e --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/MacCatalyst/Program.cs @@ -0,0 +1,16 @@ +using ObjCRuntime; +using UIKit; + +namespace SyncfusionThemeSample +{ + public class Program + { + // This is the main entry point of the application. + static void Main(string[] args) + { + // if you want to use a different Application Delegate class from "AppDelegate" + // you can specify it here. + UIApplication.Main(args, null, typeof(AppDelegate)); + } + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Tizen/Main.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Tizen/Main.cs new file mode 100644 index 0000000..02b71e3 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Tizen/Main.cs @@ -0,0 +1,17 @@ +using Microsoft.Maui; +using Microsoft.Maui.Hosting; +using System; + +namespace SyncfusionThemeSample +{ + internal class Program : MauiApplication + { + protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp(); + + static void Main(string[] args) + { + var app = new Program(); + app.Run(args); + } + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Tizen/tizen-manifest.xml b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Tizen/tizen-manifest.xml new file mode 100644 index 0000000..7759f8d --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Tizen/tizen-manifest.xml @@ -0,0 +1,15 @@ + + + + + + maui-appicon-placeholder + + + + + http://tizen.org/privilege/internet + + + + \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/App.xaml b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/App.xaml new file mode 100644 index 0000000..20c27ab --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/App.xaml @@ -0,0 +1,8 @@ + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/App.xaml.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/App.xaml.cs new file mode 100644 index 0000000..cd951df --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/App.xaml.cs @@ -0,0 +1,25 @@ +using Microsoft.UI.Xaml; + +// To learn more about WinUI, the WinUI project structure, +// and more about our project templates, see: http://aka.ms/winui-project-info. + +namespace SyncfusionThemeSample.WinUI +{ + /// + /// Provides application-specific behavior to supplement the default Application class. + /// + public partial class App : MauiWinUIApplication + { + /// + /// Initializes the singleton application object. This is the first line of authored code + /// executed, and as such is the logical equivalent of main() or WinMain(). + /// + public App() + { + this.InitializeComponent(); + } + + protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp(); + } + +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/Package.appxmanifest b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/Package.appxmanifest new file mode 100644 index 0000000..ece7c84 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/Package.appxmanifest @@ -0,0 +1,46 @@ + + + + + + + + + $placeholder$ + User Name + $placeholder$.png + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/app.manifest b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/app.manifest new file mode 100644 index 0000000..b62c835 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/Windows/app.manifest @@ -0,0 +1,15 @@ + + + + + + + + true/PM + PerMonitorV2, PerMonitor + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/AppDelegate.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/AppDelegate.cs new file mode 100644 index 0000000..4e42f93 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/AppDelegate.cs @@ -0,0 +1,10 @@ +using Foundation; + +namespace SyncfusionThemeSample +{ + [Register("AppDelegate")] + public class AppDelegate : MauiUIApplicationDelegate + { + protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp(); + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/Info.plist b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/Info.plist new file mode 100644 index 0000000..0004a4f --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/Info.plist @@ -0,0 +1,32 @@ + + + + + LSRequiresIPhoneOS + + UIDeviceFamily + + 1 + 2 + + UIRequiredDeviceCapabilities + + arm64 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + XSAppIconAssets + Assets.xcassets/appicon.appiconset + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/Program.cs b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/Program.cs new file mode 100644 index 0000000..e7cb01e --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Platforms/iOS/Program.cs @@ -0,0 +1,16 @@ +using ObjCRuntime; +using UIKit; + +namespace SyncfusionThemeSample +{ + public class Program + { + // This is the main entry point of the application. + static void Main(string[] args) + { + // if you want to use a different Application Delegate class from "AppDelegate" + // you can specify it here. + UIApplication.Main(args, null, typeof(AppDelegate)); + } + } +} diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Properties/launchSettings.json b/SyncfusionThemeSample/SyncfusionThemeSample/Properties/launchSettings.json new file mode 100644 index 0000000..edf8aad --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Properties/launchSettings.json @@ -0,0 +1,8 @@ +{ + "profiles": { + "Windows Machine": { + "commandName": "MsixPackage", + "nativeDebugging": false + } + } +} \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/AppIcon/appicon.svg b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/AppIcon/appicon.svg new file mode 100644 index 0000000..9d63b65 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/AppIcon/appicon.svg @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/AppIcon/appiconfg.svg b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/AppIcon/appiconfg.svg new file mode 100644 index 0000000..21dfb25 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/AppIcon/appiconfg.svg @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Fonts/OpenSans-Regular.ttf b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Fonts/OpenSans-Regular.ttf new file mode 100644 index 0000000..2d1edf0 Binary files /dev/null and b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Fonts/OpenSans-Regular.ttf differ diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Fonts/OpenSans-Semibold.ttf b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Fonts/OpenSans-Semibold.ttf new file mode 100644 index 0000000..fe13d06 Binary files /dev/null and b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Fonts/OpenSans-Semibold.ttf differ diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Images/dotnet_bot.png b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Images/dotnet_bot.png new file mode 100644 index 0000000..f93ce02 Binary files /dev/null and b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Images/dotnet_bot.png differ diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Raw/AboutAssets.txt b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Raw/AboutAssets.txt new file mode 100644 index 0000000..15d6244 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Raw/AboutAssets.txt @@ -0,0 +1,15 @@ +Any raw assets you want to be deployed with your application can be placed in +this directory (and child directories). Deployment of the asset to your application +is automatically handled by the following `MauiAsset` Build Action within your `.csproj`. + + + +These files will be deployed with you package and will be accessible using Essentials: + + async Task LoadMauiAsset() + { + using var stream = await FileSystem.OpenAppPackageFileAsync("AboutAssets.txt"); + using var reader = new StreamReader(stream); + + var contents = reader.ReadToEnd(); + } diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Splash/splash.svg b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Splash/splash.svg new file mode 100644 index 0000000..21dfb25 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Splash/splash.svg @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Styles/Colors.xaml b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Styles/Colors.xaml new file mode 100644 index 0000000..30307a5 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Styles/Colors.xaml @@ -0,0 +1,45 @@ + + + + + + + #512BD4 + #ac99ea + #242424 + #DFD8F7 + #9880e5 + #2B0B98 + + White + Black + #D600AA + #190649 + #1f1f1f + + #E1E1E1 + #C8C8C8 + #ACACAC + #919191 + #6E6E6E + #404040 + #212121 + #141414 + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Styles/Styles.xaml b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Styles/Styles.xaml new file mode 100644 index 0000000..e0d36bb --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/Resources/Styles/Styles.xaml @@ -0,0 +1,426 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/SyncfusionThemeSample/SyncfusionThemeSample/SyncfusionThemeSample.csproj b/SyncfusionThemeSample/SyncfusionThemeSample/SyncfusionThemeSample.csproj new file mode 100644 index 0000000..bb7e315 --- /dev/null +++ b/SyncfusionThemeSample/SyncfusionThemeSample/SyncfusionThemeSample.csproj @@ -0,0 +1,66 @@ + + + + net8.0-android;net8.0-ios;net8.0-maccatalyst + $(TargetFrameworks);net8.0-windows10.0.19041.0 + + + + + + + Exe + SyncfusionThemeSample + true + true + enable + enable + + + SyncfusionThemeSample + + + com.companyname.syncfusionthemesample + + + 1.0 + 1 + + 11.0 + 13.1 + 21.0 + 10.0.17763.0 + 10.0.17763.0 + 6.5 + + + + + + + + + + + + + + + + + + + + + + + + + + + +