Uno.Material 2.0.0-dev.170

Prefix Reserved
This is a prerelease version of Uno.Material.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Uno.Material --version 2.0.0-dev.170                
NuGet\Install-Package Uno.Material -Version 2.0.0-dev.170                
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="Uno.Material" Version="2.0.0-dev.170" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Uno.Material --version 2.0.0-dev.170                
#r "nuget: Uno.Material, 2.0.0-dev.170"                
#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.
// Install Uno.Material as a Cake Addin
#addin nuget:?package=Uno.Material&version=2.0.0-dev.170&prerelease

// Install Uno.Material as a Cake Tool
#tool nuget:?package=Uno.Material&version=2.0.0-dev.170&prerelease                

Uno Material

This library is designed to help you use the material design system. It includes :

  • Color system for both Light and Dark theme
  • Styles for existing WinUI controls like Buttons, TextBox, etc.

Quickly visualize all the available controls through this zeplin link

Platform support:

  • WinUI / UWP
  • iOS
  • MacOS
  • Android
  • WebAssembly
  • Linux (Skia.Gtk)

Uno Material

Uno Material Design Guideline is a resource for designers and software developers that combines Material and Uno design guidance in single document. It is an easy way to kickstart design and implementation of cross-platform experiences with unified Material design system look and feel, using Sketch and Uno Platform.

Download the Uno Platform Design Guidelines sketch file to get started.

It includes:

  • Uno-Material components
  • Uno type resource names
  • Uno asset naming and export guidance

License

Getting Started

  1. Install the nuget package Uno.Material.
  2. Unless you want our default color palette (inspired by our Uno logo), you'll want to override the following color resources in you application. We suggest creating a ColorPaletteOverride.xaml ResourceDictionary. For more information on the color system, consult this page for all the official documentation and tools to help you create your own palette. Here is what ColorPaletteOverride.xaml would contain if you want both light and dark theme.
<ResourceDictionary
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">

	
	<ResourceDictionary.ThemeDictionaries>
		
		<ResourceDictionary x:Key="Light">
			<Color x:Key="MaterialPrimaryColor">#5B4CF5</Color>
			<Color x:Key="MaterialPrimaryVariantDarkColor">#353FE5</Color>
			<Color x:Key="MaterialPrimaryVariantLightColor">#B6A8FB</Color>
			<Color x:Key="MaterialSecondaryColor">#67E5AD</Color>
			<Color x:Key="MaterialSecondaryVariantDarkColor">#2BB27E</Color>
			<Color x:Key="MaterialSecondaryVariantLightColor">#9CFFDF</Color>
			<Color x:Key="MaterialBackgroundColor">#FFFFFF</Color>
			<Color x:Key="MaterialSurfaceColor">#FFFFFF</Color>
			<Color x:Key="MaterialErrorColor">#F85977</Color>
			<Color x:Key="MaterialOnPrimaryColor">#FFFFFF</Color>
			<Color x:Key="MaterialOnSecondaryColor">#000000</Color>
			<Color x:Key="MaterialOnBackgroundColor">#000000</Color>
			<Color x:Key="MaterialOnSurfaceColor">#000000</Color>
			<Color x:Key="MaterialOnErrorColor">#000000</Color>
			<Color x:Key="MaterialOverlayColor">#51000000</Color>
		</ResourceDictionary>

		
		<ResourceDictionary x:Key="Dark">
			<Color x:Key="MaterialPrimaryColor">#B6A8FB</Color>
			<Color x:Key="MaterialPrimaryVariantDarkColor">#353FE5</Color>
			<Color x:Key="MaterialPrimaryVariantLightColor">#D4CBFC</Color>
			<Color x:Key="MaterialSecondaryColor">#67E5AD</Color>
			<Color x:Key="MaterialSecondaryVariantDarkColor">#2BB27E</Color>
			<Color x:Key="MaterialSecondaryVariantLightColor">#9CFFDF</Color>
			<Color x:Key="MaterialBackgroundColor">#121212</Color>
			<Color x:Key="MaterialSurfaceColor">#121212</Color>
			<Color x:Key="MaterialErrorColor">#CF6679</Color>
			<Color x:Key="MaterialOnPrimaryColor">#000000</Color>
			<Color x:Key="MaterialOnSecondaryColor">#000000</Color>
			<Color x:Key="MaterialOnBackgroundColor">#FFFFFF</Color>
			<Color x:Key="MaterialOnSurfaceColor">#DEFFFFFF</Color>
			<Color x:Key="MaterialOnErrorColor">#000000</Color>
			<Color x:Key="MaterialOverlayColor">#51FFFFFF</Color>
		</ResourceDictionary>
	</ResourceDictionary.ThemeDictionaries>
</ResourceDictionary>

  1. Initialize the material resources. The order in which the different resources are loaded is important. Add this to App.xaml
<MaterialColors xmlns="using:Uno.Material"
				OverrideSource="ms-appx:///ColorPaletteOverride.xaml" />
<MaterialResources xmlns="using:Uno.Material" />
  1. (Optional) The material ProgressBar is built on top for the WinUI ProgressBar so make sure you include the appropriate resources in your App.xaml
	<Application.Resources>
		<ResourceDictionary>
			<ResourceDictionary.MergedDictionaries>
				
				<XamlControlsResources xmlns="using:Microsoft.UI.Xaml.Controls"/>

				<MaterialColors xmlns="using:Uno.Material"
								OverrideSource="ms-appx:///ColorPaletteOverride.xaml" />
				<MaterialResources xmlns="using:Uno.Material" />
				
				
			</ResourceDictionary.MergedDictionaries>
		</ResourceDictionary>
	</Application.Resources>
  1. Start using the styles in your pages!
  • To use styles, just find the name of the style from our documentation or sample app and use it like this
<Button Content="CONTAINED"
	Style="{StaticResource MaterialContainedButtonStyle}"/>
  1. In order to display the appropriate font with the material styles on Webassembly, make sure that the Roboto font is defined on font.css located at [YourProject].Wasm/WasmCSS. This make sure that the font is loaded correctly Related Issue. It should look like this:
@font-face {
  font-family: "Symbols";
  /* winjs-symbols.woff2: https://github.com/Microsoft/fonts/tree/master/Symbols */
  src: url(data:application/x-font-woff;charset=utf-8;base64,[...]);
}

@font-face {
  font-family: "Roboto";
  src: url(data:application/x-font-woff;charset=utf-8;base64,[...]);
}

body::after {
	font-family: 'Roboto';
	background: transparent;
	content: "";
	opacity: 0;
	pointer-events: none;
	position: absolute;
}
  1. (Optional) Set material styles as the default for your whole application.

     <MaterialResources xmlns="using:Uno.Material" WithImplicitStyles="True" />
    

    Alternatively, if you wish to only have the default styles for certain controls, simply add the implicit styles to your App.xaml:

     <Application.Resources>
     	<ResourceDictionary>
     		<ResourceDictionary.MergedDictionaries>
     			<MaterialColors xmlns="using:Uno.Material" />
     			<MaterialResources xmlns="using:Uno.Material" />
    
    
     			<ResourceDictionary>
     				<Style TargetType="Button" BasedOn="{StaticResource MaterialContainedButtonStyle}"/>
     				<Style TargetType="TextBox" BasedOn="{StaticResource MaterialFilledTextBoxStyle}"/>
     			</ResourceDictionary>
     		</ResourceDictionary.MergedDictionaries>
     	</ResourceDictionary>
     </Application.Resources>
    

    Learn more about implicit styles from the Microsoft documentation here

  2. (Optional) Per-control customization. Just like WinUI, we documented a set of control-specific resources you can override to further customize our controls. For example, if you would like change the CornerRadius of all the Buttons using our material styles, you could simply override the ButtonBorderRadius value in your resources (in App.xaml would be the simplest way to put the following code)

<CornerRadius x:Key="ButtonBorderRadius">4</CornerRadius>
  1. (Optional) If you are using our ToggleSwitches to get proper Material styling in Android there is some extra code to be added to the Android Project Head. (Click the component name to see how to set them up)

  2. (Optional) If you are using our DatePickers, and TimePickers to get proper Material styling in Android there is some extra code to be added to the Android Project Head. (Click the component name to see how to set them up)

Features

Styles for basic controls

Controls StyleNames
Button MaterialContainedButtonStyle <br> MaterialOutlinedButtonStyle <br> MaterialTextButtonStyle <br> MaterialButtonIconStyle <br> MaterialContainedSecondaryButtonStyle <br> MaterialOutlinedSecondaryButtonStyle<br> MaterialTextSecondaryButtonStyle <br> MaterialButtonIconStyle
Button (FAB) <br> Floating Action Button MaterialFabStyle <br> MaterialSmallFabStyle <br> MaterialSecondaryFabStyle <br> MaterialPrimaryInvertedFabStyle <br> MaterialSecondaryInvertedFabStyle
CalendarDatePicker MaterialCalendarDatePickerStyle
CalendarView MaterialCalendarViewStyle
CheckBox MaterialCheckBoxStyle <br> MaterialSecondaryCheckBoxStyle
ComboBox MaterialComboBoxStyle <br> MaterialComboBoxItemStyle
CommandBar MaterialCommandBarStyle <br> MaterialAppBarButton
DatePicker MaterialDatePickerStyle
Flyout MaterialFlyoutPresenterStyle <br> MaterialContentFlyoutPresenterStyle
MenuFlyout MaterialMenuFMaterialMUXNoCompactMenuNavigationViewStylelyoutPresenterStyle <br> MaterialMenuFlyoutItemStyle <br> MaterialToggleMenuFlyoutItemStyle <br> MaterialMenuFlyoutSubItemStyle <br> MaterialMenuFlyoutSeparatorStyle
HyperlinkButton MaterialHyperlinkButtonStyle <br> MaterialSecondaryHyperlinkButtonStyle
muxc:InfoBar MaterialInfoBarStyle
ListView MaterialListViewStyle <br> MaterialListViewDetailsStyle <br> MaterialListViewItemStyle
NavigationView MaterialWUXNavigationViewStyle <br> MaterialWUXNoCompactMenuNavigationViewStyle <br> MaterialWUXNavigationViewItemStyle
muxc:NavigationView MaterialNavigationViewStyle <br> MaterialNavigationViewItemStyle
PasswordBox MaterialFilledPasswordBoxStyle <br> MaterialOutlinedPasswordBoxStyle
muxc:ProgressBar MaterialProgressBarStyle <br> MaterialSecondaryProgressBarStyle
muxc:ProgressRing MaterialProgressRingStyle <br> MaterialSecondaryProgressRingStyle
RadioButton MaterialRadioButtonStyle <br> MaterialSecondaryRadioButtonStyle
muxc:RatingControl MaterialRatingControlStyle <br> MaterialSecondaryRatingControlStyle
muxc:Slider MaterialSliderStyle <br> MaterialSecondarySliderStyle
TextBlock MaterialHeadline1 <br> MaterialHeadline2 <br> MaterialHeadline3 <br> MaterialHeadline4 <br> MaterialHeadline5 <br> MaterialHeadline6 <br> MaterialSubtitle1 <br> MaterialSubtitle2 <br> MaterialBody1 <br> MaterialBody2 <br> MaterialButtonText <br> MaterialCaption <br> MaterialOverline
TextBox MaterialFilledTextBoxStyle <br> MaterialOutlinedTextBoxStyle
ToggleButton MaterialTextToggleButtonStyle <br> MaterialToggleButtonIconStyle
ToggleSwitch MaterialToggleSwitchStyle <br> MaterialSecondaryToggleSwitchStyle

Controls Setup (Specialized)

ToggleSwitch

If you are using our ToggleSwitches to get the proper native colors on android their is some modification needed. The reasoning for this is to apply the native android shadowing on the off value of the ToggleSwitch, and proper focus shadow colors when ToggleSwitches are clicked

  1. From your Android project head go to YourProject.Droid/Resources/values/Styles.xml Inside your AppTheme add two item's "colorControlActivated" (the on color for your ToggleSwitches thumb) and "colorSwitchThumbNormal" (the off color for your ToggleSwitches thumb) you may add your colors here directly, for example #ffffff, or by files (see our example code below)
<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<style name="AppTheme" parent="Theme.AppCompat.Light">

		
		<item name="colorControlActivated">@color/MaterialPrimaryColor</item>
		<item name="colorSwitchThumbNormal">@color/MaterialSurfaceVariantColor</item>
	</style>
</resources>

  1. (Optional) If your application uses Light/Dark color palettes. 2.1 Inside the Styles.xml file change the AppTheme's parent to Theme.Compat.DayNight
<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<style name="AppTheme" parent="Theme.AppCompat.DayNight">

		
		<item name="colorControlActivated">@color/MaterialPrimaryColor</item>
		<item name="colorSwitchThumbNormal">@color/MaterialSurfaceVariantColor</item>
	</style>
</resources>

2.2 From your Android project head go to YourProject.Droid/Resources/values create a file called "colors.xml", inside include your "Light" theme colors.

<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<color name="MaterialPrimaryColor">#5B4CF5</color>
	
	<color name="MaterialSurfaceVariantColor">#FFFFFF</color>
</resources>

2.3 From your Android project head go to YourProject.Droid/Resources create a folder called "values-night", inside the folder add a file called "colors.xml", and inside the file include your "Dark" theme colors.

<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<color name="MaterialPrimaryColor">#B6A8FB</color>
	
	 <color name="MaterialSurfaceVariantColor">#808080</color>
</resources>

2.3 (Optional) If you have changed the material color palette for your application (2.) then there are two more colors that must be overridden for android native ToggleSwitch disabled colors to be properly applied. Colors are named PrimaryVariantDisabledThumbColor and SurfaceVariantLightColor, they can be overridden in your colors.xaml file. PrimaryVariantDisabledThumbColor is a non-transparent version of PrimaryDisabled color ("Light") in "Light" palette, and a non-transparent version of PrimaryMedium color ("Dark") in "Dark" palette. SurfaceVariantLightColor is the Surface color however in "Light" Palette is an off white color to be visible on light backgrounds.


	<ResourceDictionary.ThemeDictionaries>

		
		<ResourceDictionary x:Key="Light">
			
			<Color x:Key="PrimaryVariantDisabledThumbColor">#E9E5FA</Color>
			
			<Color x:Key="SurfaceVariantLightColor">#F7F7F7</Color>
		</ResourceDictionary>

		
		<ResourceDictionary x:Key="Dark">
			
			<Color x:Key="PrimaryVariantDisabledThumbColor">#57507C</Color>
			<Color x:Key="SurfaceVariantLightColor">#121212</Color>
		</ResourceDictionary>
	</ResourceDictionary.ThemeDictionaries>

DatePickers and TimePickers

If your application uses DatePickers and/or TimePickers (these are native components). To apply your material colors to these android components, do the following (this will affect every DatePicker/TimePicker in the application).

  1. From your Android project head go to YourProject.Droid/Resources/values/Styles.xml Inside your AppTheme add two item's "datePickerDialogTheme" (the style for your DatePicker) and "timePickerDialogTheme" (the style for your TimePicker), and a new Style with the MaterialPrimary Color as AccentColor (see our example code below)
<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<style name="AppTheme" parent="Theme.AppCompat.Light">

		
		<item name="android:datePickerDialogTheme">@style/AppCompatDialogStyle</item>
		<item name="android:timePickerDialogTheme">@style/AppCompatDialogStyle</item>
	</style>

	<style name="AppCompatDialogStyle" parent="Theme.AppCompat.Light.Dialog">
		<item name="colorAccent">@color/MaterialPrimaryColor</item>
	</style>
</resources>

  1. (Optional) If your application uses Light/Dark color palettes. 2.1 Inside the Styles.xml file change the AppTheme's parent of both styles to Theme.Compat.DayNight
<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<style name="AppTheme" parent="Theme.AppCompat.DayNight">

		
		<item name="android:datePickerDialogTheme">@style/AppCompatDialogStyle</item>
		<item name="android:timePickerDialogTheme">@style/AppCompatDialogStyle</item>
	</style>

	<style name="AppCompatDialogStyle" parent="Theme.AppCompat.DayNight.Dialog">
		<item name="colorAccent">@color/MaterialPrimaryColor</item>
	</style>
</resources>

2.2 From your Android project head go to YourProject.Droid/Resources/values create a file called "colors.xml", inside include your "Light" theme colors.

<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<color name="MaterialPrimaryColor">#5B4CF5</color>
</resources>

2.3 From your Android project head go to YourProject.Droid/Resources create a folder called "values-night", inside the folder add a file called "colors.xml", and inside the file include your "Dark" theme colors.

<?xml version="1.0" encoding="utf-8" ?>
<resources>
	<color name="MaterialPrimaryColor">#B6A8FB</color>
</resources>

Migration

1.0 to 1.1

  • Color Palette Override

    Now you have the possibility to override the Material color palette with your own color palette. See the #Getting Started section for more details.

      <MaterialColors xmlns="using:Uno.Material"
      				OverrideSource="ms-appx:///ColorPaletteOverride.xaml" />
    
  • Namespace breaking changes

    BREAKING CHANGE: Everything (controls, extensions, converters, ...), previously under Uno.Material.* or Uno.Cupertino.*, has now been moved under Uno.Material or Uno.Cupertino.

      xmlns:um="using:Uno.Material"
      xmlns:uc="using:Uno.Cupertino"
    
  • Some controls have been moved to Uno.Toolkit.UI

    List of the controls and styles that have been moved to Uno.Toolkit.UI:

    Controls StyleNames
    Card MaterialOutlinedCardStyle <br> MaterialElevatedCardStyle <br> MaterialAvatarOutlinedCardStyle <br> MaterialAvatarElevatedCardStyle <br> MaterialSmallMediaOutlinedCardStyle <br> MaterialSmallMediaElevatedCardStyle
    Chip MaterialFilledInputChipStyle<br>MaterialFilledChoiceChipStyle<br>MaterialFilledFilterChipStyle<br>MaterialFilledActionChipStyle<br>MaterialOutlinedInputChipStyle<br>MaterialOutlinedChoiceChipStyle<br>MaterialOutlinedFilterChipStyle<br>MaterialOutlinedActionChipStyle
    ChipGroup MaterialFilledInputChipGroupStyle<br>MaterialFilledChoiceChipGroupStyle<br>MaterialFilledFilterChipGroupStyle<br>MaterialFilledActionChipGroupStyle<br>MaterialOutlinedInputChipGroupStyle<br>MaterialOutlinedChoiceChipGroupStyle<br>MaterialOutlinedFilterChipGroupStyle<br>MaterialOutlinedActionChipGroupStyle
    Divider MaterialDividerStyle
  • Some controls have been removed

    List of the controls and styles that have been removed from Uno.Themes:

    Controls StyleNames
    BottomNavigationBar MaterialBottomNavigationBarStyle
    ExpandingBottomSheet MaterialExpandingBottomSheetStyle
    ModalStandardBottomSheet MaterialModalStandardBottomSheetStyle
    StandardBottomSheet MaterialStandardBottomSheetStyle
    SnackBar MaterialSnackBarStyle
    • BottomNavigationBar was replaced by TabBar in Uno.Toolkit.UI, but it is not an exact 1:1 replacement. In the mean time, if you really need the badge and/or other customizability, two options are available:

      Import locally the old sources (control + style) from Uno.Themes;

      OR

      Copy the MaterialBottomTabBarItemStyle from Uno.Toolkit.UI, and modify the style to suit your needs. (Note that there are two copies of the style, one for iOS and Android and one for rest of the platforms: UWP, Skia, WASM, etc...);

    • For StandardBottomSheet and ModalStandardBottomSheet It's replaced by using a Flyout and the MaterialFlyoutPresenterStyle that is allowing you to have a bottom sheet.

      For example:

        <Flyout Placement="Full"
              LightDismissOverlayMode="On"
              FlyoutPresenterStyle="{StaticResource MaterialFlyoutPresenterStyle}">
        	<Grid MaxHeight="370"
        		  VerticalAlignment="Bottom">
        		...Your bottom sheet content...
        	</Grid>
        </Flyout>
      
    • For SnackBar: so far no replacement for SnackBar has been added to Uno.Toolkit.UI, but it's planned to add one in a future version.

Changelog

Please consult the CHANGELOG for more information about version history.

License

This project is licensed under the Apache 2.0 license - see the LICENSE file for details.

Contributing

Please read CONTRIBUTING.md for details on the process for contributing to this project.

Be mindful of our Code of Conduct.

Acknowledgments

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-android31.0 is compatible.  net6.0-ios was computed.  net6.0-ios15.2 is compatible.  net6.0-maccatalyst was computed.  net6.0-maccatalyst15.2 is compatible.  net6.0-macos was computed.  net6.0-macos12.1 is compatible.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed.  monoandroid11.0 is compatible. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Universal Windows Platform uap10.0.18362 is compatible. 
Xamarin.iOS xamarinios was computed.  xamarinios10 is compatible. 
Xamarin.Mac xamarinmac was computed.  xamarinmac20 is compatible. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Uno.Material:

Package Downloads
Uno.Toolkit.UI.Material

A set of controls for Uno Platform, UWP and WinUI

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Uno.Material:

Repository Stars
unoplatform/Uno.Samples
A collection of code samples for the Uno Platform
Version Downloads Last updated
5.3.0-dev.8 273 9/19/2024
5.3.0-dev.6 31 9/19/2024
5.3.0-dev.5 34 9/19/2024
5.3.0-dev.4 278 9/16/2024
5.3.0-dev.3 105 9/11/2024
5.3.0-dev.1 52 9/11/2024
5.2.5 97 9/25/2024
5.2.0-dev.23 97 9/9/2024
5.2.0-dev.22 92 9/4/2024
5.2.0-dev.21 35 9/4/2024
5.2.0-dev.20 52 9/3/2024
5.2.0-dev.17 198 8/23/2024
5.2.0-dev.16 89 8/21/2024
5.2.0-dev.15 184 8/9/2024
5.2.0-dev.14 98 7/31/2024
5.2.0-dev.13 171 7/16/2024
5.2.0-dev.11 47 7/15/2024
5.2.0-dev.9 349 6/25/2024
5.2.0-dev.7 60 6/20/2024
5.2.0-dev.5 48 6/20/2024
5.2.0-dev.3 45 6/19/2024
5.2.0-dev.2 49 6/18/2024
5.2.0-dev.1 42 6/17/2024
5.1.9 106 9/11/2024
5.1.7 147 7/22/2024
5.1.6 145 7/22/2024
5.1.0-dev.36 206 6/4/2024
5.1.0-dev.35 86 6/4/2024
5.1.0-dev.33 148 5/30/2024
5.1.0-dev.31 225 5/23/2024
5.1.0-dev.29 55 5/23/2024
5.1.0-dev.26 226 5/13/2024
5.1.0-dev.25 45 5/13/2024
5.1.0-dev.24 76 5/11/2024
5.1.0-dev.23 98 5/9/2024
5.1.0-dev.19 267 4/23/2024
5.1.0-dev.18 162 4/16/2024
5.1.0-dev.16 47 4/16/2024
5.1.0-dev.13 100 4/13/2024
5.1.0-dev.12 61 4/12/2024
5.1.0-dev.11 65 4/11/2024
5.1.0-dev.10 53 4/11/2024
5.1.0-dev.8 91 4/8/2024
5.0.13 512 4/22/2024
5.0.0-dev.86 180 4/3/2024
4.2.0-dev.31 56 4/3/2024
4.2.0-dev.30 102 3/28/2024
4.2.0-dev.26 113 3/25/2024
4.2.0-dev.25 78 3/22/2024
4.2.0-dev.24 53 3/22/2024
4.2.0-dev.19 391 3/2/2024
4.2.0-dev.18 128 2/25/2024
4.2.0-dev.17 3,956 2/13/2024
4.2.0-dev.12 158 2/7/2024
4.2.0-dev.11 147 2/6/2024
4.2.0-dev.10 80 2/5/2024
4.2.0-dev.9 234 2/1/2024
4.2.0-dev.6 164 1/31/2024
4.2.0-dev.5 79 1/30/2024
4.2.0-dev.2 63 1/29/2024
4.2.0-dev.1 54 1/29/2024
4.1.1 231 2/2/2024
4.1.0 386 1/30/2024
4.1.0-dev.52 109 1/24/2024
4.1.0-dev.50 56 1/24/2024
4.1.0-dev.49 196 1/12/2024
4.1.0-dev.45 374 12/20/2023
4.1.0-dev.43 76 12/20/2023
4.1.0-dev.39 848 12/13/2023
4.1.0-dev.35 171 12/6/2023
4.1.0-dev.33 93 12/5/2023
4.1.0-dev.32 97 12/4/2023
4.1.0-dev.31 125 12/1/2023
4.1.0-dev.30 95 11/29/2023
4.1.0-dev.29 190 11/21/2023
4.1.0-dev.28 102 11/18/2023
4.1.0-dev.27 89 11/17/2023
4.1.0-dev.26 65 11/16/2023
4.1.0-dev.25 69 11/16/2023
4.1.0-dev.24 1,008 11/13/2023
4.1.0-dev.19 197 11/6/2023
4.1.0-dev.17 70 11/6/2023
4.1.0-dev.15 70 11/6/2023
4.1.0-dev.8 151 11/3/2023
4.1.0-dev.7 76 11/3/2023
4.1.0-dev.1 166 10/30/2023
4.0.6 273 11/7/2023
4.0.4 860 11/1/2023
4.0.0-dev.188 124 10/27/2023
4.0.0-dev.187 75 10/27/2023
4.0.0-dev.186 99 10/26/2023
4.0.0-dev.184 79 10/26/2023
4.0.0-dev.183 92 10/26/2023
4.0.0-dev.182 133 10/24/2023
4.0.0-dev.180 299 10/13/2023
4.0.0-dev.178 151 10/10/2023
4.0.0-dev.175 79 10/10/2023
4.0.0-dev.174 167 10/6/2023
4.0.0-dev.167 124 10/4/2023
4.0.0-dev.166 72 10/4/2023
4.0.0-dev.164 100 10/3/2023
4.0.0-dev.162 102 10/2/2023
4.0.0-dev.161 121 9/30/2023
4.0.0-dev.160 102 9/29/2023
4.0.0-dev.159 79 9/29/2023
4.0.0-dev.157 81 9/29/2023
4.0.0-dev.156 92 9/29/2023
4.0.0-dev.152 74 9/28/2023
4.0.0-dev.151 75 9/28/2023
4.0.0-dev.150 74 9/28/2023
4.0.0-dev.149 79 9/28/2023
4.0.0-dev.148 69 9/28/2023
4.0.0-dev.147 77 9/28/2023
4.0.0-dev.146 115 9/26/2023
4.0.0-dev.140 146 9/22/2023
4.0.0-dev.139 96 9/20/2023
4.0.0-dev.126 451 8/30/2023
4.0.0-dev.124 142 8/30/2023
3.1.0-dev.96 1,639 8/31/2023
3.1.0-dev.94 114 8/30/2023
3.0.40 468 9/6/2023
2.8.0-dev.6 414 8/30/2023
2.8.0-dev.2 128 8/29/2023
2.7.0-dev.104 312 8/16/2023
2.7.0-dev.102 591 8/16/2023
2.7.0-dev.99 94 8/15/2023
2.7.0-dev.97 221 8/11/2023
2.7.0-dev.95 94 8/11/2023
2.7.0-dev.89 104 8/10/2023
2.7.0-dev.88 125 8/7/2023
2.7.0-dev.86 93 8/7/2023
2.7.0-dev.84 101 8/7/2023
2.7.0-dev.81 103 8/7/2023
2.7.0-dev.61 94 8/7/2023
2.7.0-dev.59 141 8/4/2023
2.7.0-dev.56 108 8/3/2023
2.7.0-dev.54 103 8/3/2023
2.7.0-dev.53 164 8/1/2023
2.7.0-dev.47 106 8/1/2023
2.7.0-dev.45 108 8/1/2023
2.7.0-dev.41 126 7/31/2023
2.7.0-dev.39 316 7/26/2023
2.7.0-dev.37 106 7/26/2023
2.7.0-dev.35 99 7/25/2023
2.7.0-dev.33 111 7/24/2023
2.7.0-dev.31 109 7/24/2023
2.7.0-dev.29 113 7/24/2023
2.7.0-dev.27 106 7/24/2023
2.7.0-dev.25 95 7/14/2023
2.7.0-dev.23 99 7/12/2023
2.7.0-dev.21 136 6/29/2023
2.7.0-dev.20 100 6/27/2023
2.7.0-dev.19 93 6/27/2023
2.7.0-dev.18 118 6/19/2023
2.7.0-dev.17 103 6/16/2023
2.7.0-dev.16 107 6/14/2023
2.7.0-dev.15 103 6/13/2023
2.7.0-dev.13 89 6/13/2023
2.7.0-dev.12 96 6/12/2023
2.7.0-dev.11 172 6/7/2023
2.7.0-dev.10 92 6/7/2023
2.7.0-dev.8 100 6/7/2023
2.7.0-dev.7 99 6/5/2023
2.7.0-dev.6 94 6/5/2023
2.7.0-dev.5 100 6/2/2023
2.7.0-dev.2 108 5/30/2023
2.7.0-dev.1 99 5/30/2023
2.6.1 392 6/7/2023
2.6.0 2,516 6/5/2023
2.6.0-dev.25 370 5/28/2023
2.6.0-dev.24 124 5/25/2023
2.6.0-dev.21 102 5/25/2023
2.6.0-dev.19 191 5/16/2023
2.6.0-dev.17 235 5/4/2023
2.6.0-dev.14 486 3/28/2023
2.6.0-dev.5 201 3/16/2023
2.6.0-dev.2 157 3/13/2023
2.5.3 3,339 3/16/2023
2.5.2 207 3/16/2023
2.5.0-dev.44 131 3/10/2023
2.5.0-dev.43 135 3/9/2023
2.5.0-dev.41 142 3/8/2023
2.5.0-dev.40 167 3/4/2023
2.5.0-dev.39 137 3/2/2023
2.5.0-dev.38 156 2/28/2023
2.5.0-dev.37 1,387 2/23/2023
2.5.0-dev.34 223 2/22/2023
2.5.0-dev.31 154 2/17/2023
2.5.0-dev.26 124 2/16/2023
2.5.0-dev.20 140 2/15/2023
2.5.0-dev.19 169 2/8/2023
2.5.0-dev.15 574 1/23/2023
2.5.0-dev.14 222 1/13/2023
2.5.0-dev.10 135 1/12/2023
2.5.0-dev.6 159 12/31/2022
2.5.0-dev.3 138 12/23/2022
2.5.0-dev.1 131 12/22/2022
2.4.1 3,122 12/13/2022
2.4.0-dev.68 298 11/24/2022
2.4.0-dev.66 100 11/23/2022
2.4.0-dev.64 129 11/17/2022
2.4.0-dev.62 164 11/7/2022
2.4.0-dev.60 119 11/3/2022
2.4.0-dev.59 100 11/3/2022
2.4.0-dev.57 105 11/3/2022
2.4.0-dev.53 112 11/2/2022
2.4.0-dev.46 143 11/1/2022
2.4.0-dev.42 139 10/27/2022
2.4.0-dev.40 112 10/27/2022
2.4.0-dev.38 156 10/20/2022
2.4.0-dev.33 765 10/6/2022
2.4.0-dev.31 507 9/30/2022
2.4.0-dev.29 105 9/30/2022
2.4.0-dev.26 116 9/29/2022
2.4.0-dev.24 101 9/29/2022
2.4.0-dev.19 168 9/22/2022
2.4.0-dev.17 115 9/21/2022
2.4.0-dev.13 140 9/15/2022
2.4.0-dev.11 167 9/14/2022
2.4.0-dev.7 149 9/14/2022
2.3.0 6,620 9/12/2022
2.3.0-dev.20 118 9/9/2022
2.3.0-dev.17 111 9/9/2022
2.3.0-dev.12 1,818 8/31/2022
2.3.0-dev.10 100 8/31/2022
2.3.0-dev.8 104 8/30/2022
2.3.0-dev.6 3,853 8/12/2022
2.3.0-dev.4 726 7/22/2022
2.2.0 1,464 6/29/2022
2.2.0-dev.7 132 6/28/2022
2.2.0-dev.5 154 6/20/2022
2.2.0-dev.2 135 6/17/2022
2.1.0 3,742 6/10/2022
2.1.0-dev.51 132 6/10/2022
2.1.0-dev.48 139 6/8/2022
2.1.0-dev.46 123 6/8/2022
2.1.0-dev.44 131 6/8/2022
2.1.0-dev.42 118 6/7/2022
2.1.0-dev.40 607 6/7/2022
2.1.0-dev.37 161 6/3/2022
2.1.0-dev.35 123 6/3/2022
2.1.0-dev.33 119 6/3/2022
2.1.0-dev.31 144 6/3/2022
2.1.0-dev.29 129 6/3/2022
2.1.0-dev.27 134 6/2/2022
2.1.0-dev.25 125 6/2/2022
2.1.0-dev.23 114 6/2/2022
2.1.0-dev.20 122 6/2/2022
2.1.0-dev.18 124 6/2/2022
2.1.0-dev.16 122 6/1/2022
2.1.0-dev.13 123 6/1/2022
2.1.0-dev.11 130 6/1/2022
2.1.0-dev.9 124 6/1/2022
2.1.0-dev.5 163 5/24/2022
2.1.0-dev.2 119 5/23/2022
2.0.0 872 5/23/2022
2.0.0-dev.228 121 5/23/2022
2.0.0-dev.226 125 5/23/2022
2.0.0-dev.224 118 5/23/2022
2.0.0-dev.222 119 5/23/2022
2.0.0-dev.220 127 5/23/2022
2.0.0-dev.218 120 5/23/2022
2.0.0-dev.216 166 5/21/2022
2.0.0-dev.214 115 5/21/2022
2.0.0-dev.210 367 5/20/2022
2.0.0-dev.208 125 5/20/2022
2.0.0-dev.206 126 5/19/2022
2.0.0-dev.204 121 5/19/2022
2.0.0-dev.203 124 5/19/2022
2.0.0-dev.201 181 5/13/2022
2.0.0-dev.198 121 5/13/2022
2.0.0-dev.195 385 5/12/2022
2.0.0-dev.193 147 5/11/2022
2.0.0-dev.191 125 5/10/2022
2.0.0-dev.189 133 5/10/2022
2.0.0-dev.187 118 5/9/2022
2.0.0-dev.185 120 5/9/2022
2.0.0-dev.183 123 5/3/2022
2.0.0-dev.181 180 4/28/2022
2.0.0-dev.179 472 4/28/2022
2.0.0-dev.177 126 4/27/2022
2.0.0-dev.175 136 4/25/2022
2.0.0-dev.172 215 4/22/2022
2.0.0-dev.170 125 4/22/2022
2.0.0-dev.168 150 4/21/2022
2.0.0-dev.166 127 4/21/2022
2.0.0-dev.164 131 4/21/2022
2.0.0-dev.162 126 4/20/2022
2.0.0-dev.156 136 4/16/2022
2.0.0-dev.154 209 4/14/2022
2.0.0-dev.152 132 4/14/2022
2.0.0-dev.150 125 4/13/2022
2.0.0-dev.146 125 4/13/2022
1.4.0-dev.34 453 4/12/2022
1.4.0-dev.30 913 3/31/2022
1.4.0-dev.21 126 3/30/2022
1.4.0-dev.17 267 3/25/2022
1.4.0-dev.12 283 3/24/2022
1.4.0-dev.6 446 3/8/2022
1.3.3 6,402 4/12/2022
1.3.2 141 4/11/2022
1.3.1 999 3/9/2022
1.3.0-dev.19 3,879 1/10/2022
1.3.0-dev.17 157 1/4/2022
1.3.0-dev.12 144 1/3/2022
1.3.0-dev.4 261 12/17/2021
1.2.0 3,460 12/15/2021
1.2.0-dev.15 187 12/15/2021
1.2.0-dev.13 200 12/15/2021
1.2.0-dev.8 224 12/8/2021
1.2.0-dev.6 302 12/8/2021
1.2.0-dev.4 202 12/7/2021
1.2.0-dev.2 210 12/7/2021
1.1.0 296 12/6/2021
1.1.0-dev.70 642 12/2/2021
1.1.0-dev.68 193 12/2/2021
1.1.0-dev.66 1,439 12/1/2021
1.1.0-dev.64 1,292 11/29/2021
1.1.0-dev.62 1,824 11/26/2021
1.1.0-dev.57 3,213 11/25/2021
1.1.0-dev.55 2,755 11/25/2021
1.1.0-dev.53 2,994 11/24/2021
1.1.0-dev.51 2,731 11/24/2021
1.1.0-dev.49 3,987 11/24/2021
1.1.0-dev.47 3,216 11/24/2021
1.1.0-dev.45 2,967 11/24/2021
1.1.0-dev.43 5,651 11/23/2021
1.1.0-dev.41 203 11/23/2021
1.1.0-dev.39 200 11/23/2021
1.1.0-dev.37 305 11/22/2021
1.1.0-dev.35 512 11/21/2021
1.1.0-dev.33 497 11/21/2021
1.1.0-dev.31 788 11/19/2021
1.1.0-dev.29 704 11/19/2021
1.1.0-dev.27 224 11/19/2021
1.1.0-dev.25 280 11/19/2021
1.1.0-dev.22 197 11/19/2021
1.1.0-dev.19 272 11/19/2021
1.1.0-dev.17 255 11/18/2021
1.1.0-dev.15 290 11/17/2021
1.1.0-dev.13 362 11/15/2021
1.1.0-dev.11 199 11/15/2021
1.1.0-dev.9 231 11/15/2021
1.1.0-dev.7 503 11/9/2021
1.1.0-dev.5 264 10/29/2021
1.0.3 550 11/3/2021
1.0.2 5,225 11/2/2021
1.0.0-dev.851 273 10/28/2021
1.0.0-dev.848 213 10/27/2021
1.0.0-dev.846 249 10/26/2021
1.0.0-dev.844 210 10/25/2021
1.0.0-dev.842 822 10/20/2021
1.0.0-dev.840 228 10/20/2021
1.0.0-dev.838 708 10/15/2021
1.0.0-dev.836 197 10/14/2021
1.0.0-dev.834 562 10/7/2021
1.0.0-dev.832 940 10/4/2021
1.0.0-dev.830 457 9/29/2021
1.0.0-dev.827 1,198 9/16/2021
1.0.0-dev.825 3,193 9/14/2021
1.0.0-dev.823 318 9/8/2021
1.0.0-dev.812 10,551 9/3/2021
1.0.0-dev.810 648 8/27/2021
1.0.0-dev.802 359 8/6/2021
1.0.0-dev.796 1,110 8/4/2021
1.0.0-dev.794 232 8/4/2021
1.0.0-dev.792 233 8/4/2021
1.0.0-dev.790 2,451 7/29/2021
1.0.0-dev.788 1,759 7/14/2021
1.0.0-dev.786 915 7/13/2021
1.0.0-dev.784 1,208 6/14/2021
1.0.0-dev.782 307 6/10/2021
1.0.0-dev.780 790 6/9/2021
1.0.0-dev.778 2,021 6/8/2021
1.0.0-dev.774 529 6/7/2021
1.0.0-dev.772 444 6/1/2021
1.0.0-dev.770 317 5/31/2021
1.0.0-dev.766 321 5/26/2021
1.0.0-dev.764 229 5/19/2021
1.0.0-dev.762 220 5/19/2021
1.0.0-dev.760 312 5/7/2021
1.0.0-dev.758 265 5/5/2021
1.0.0-dev.755 227 5/4/2021
1.0.0-dev.753 248 4/30/2021
1.0.0-dev.751 631 4/29/2021
1.0.0-dev.746 3,090 4/26/2021
1.0.0-dev.744 238 4/26/2021
1.0.0-dev.742 640 4/9/2021
1.0.0-dev.738 242 4/7/2021
1.0.0-dev.736 1,069 3/24/2021
1.0.0-dev.734 290 3/23/2021
1.0.0-dev.732 784 3/19/2021
1.0.0-dev.726 251 3/19/2021
1.0.0-dev.715 320 3/17/2021
1.0.0-dev.674 263 3/4/2021
1.0.0-dev.637 697 2/26/2021
1.0.0-dev.625 275 2/16/2021
1.0.0-dev.612 802 2/10/2021
1.0.0-dev.603 453 2/9/2021
1.0.0-dev.600 296 2/8/2021
1.0.0-dev.598 3,237 2/5/2021
1.0.0-dev.592 3,230 1/28/2021
1.0.0-dev.589 1,545 1/20/2021
1.0.0-dev.585 303 1/12/2021
1.0.0-dev.578 20,237 10/29/2020
1.0.0-dev.515 2,395 8/12/2020
1.0.0-dev.507 948 8/12/2020

#  (2022-04-22)


### Bug Fixes

* [Material][Textbox] Add press state to delete button ([41c6713](https://github.com/unoplatform/Uno.Themes/commit/41c6713c6882daf7971767d29ac36df18db2851b))
* Add missing color brushes ([959fe36](https://github.com/unoplatform/Uno.Themes/commit/959fe36a6adb3d8747b7a188dc9d03965f69cd7d))
* **CheckBox:** Avoid resource name clash for Path Data resources with xamlmerge ([77e2b76](https://github.com/unoplatform/Uno.Themes/commit/77e2b761a605e04c30067154a7a8e5647bdc4061))
* Made TextBox uniform with PasswordBox. ([3ca25dd](https://github.com/unoplatform/Uno.Themes/commit/3ca25dd1e804039ed677f8a9e7de5c985084a635))
* material toggleswitch min-width ([c6066d2](https://github.com/unoplatform/Uno.Themes/commit/c6066d264eeaea7416af448e640163ae6af8e538))
* Remove PointerFocused VisualState Setters ([8d49604](https://github.com/unoplatform/Uno.Themes/commit/8d4960468b1b60763c9f1afa93343e4391aea932))
* Removed an old code piece. ([32a1544](https://github.com/unoplatform/Uno.Themes/commit/32a154457b4ca69401cefaf694e81a0793fde592))
* resource namespace mismatch ([537045e](https://github.com/unoplatform/Uno.Themes/commit/537045eeab1ce3488fd2e1a061b067655d52241e))
* uwp crash with WithImplicitStyles ([bc3b542](https://github.com/unoplatform/Uno.Themes/commit/bc3b542cfcc3e2ab319a12d845575424e245bbd3))


### Features

* Add M3 CalendarView/Picker styles, fix broken styles ([b63a189](https://github.com/unoplatform/Uno.Themes/commit/b63a1890947584c90947d266d8e9706a7726a885))
* Add M3 CommandBar/AppBarButton styles ([0dc2971](https://github.com/unoplatform/Uno.Themes/commit/0dc297146d25e05b798884167cebf2838083f9b3))
* Add M3 Common Buttons styles and samples ([6455233](https://github.com/unoplatform/Uno.Themes/commit/6455233bbfc436fc9e6de295f9a19190daf929ee))
* Add M3 ListView styles ([5d94ec3](https://github.com/unoplatform/Uno.Themes/commit/5d94ec3adbff2a65df46ec32f6f635a3a571c9b5))
* Add Material Design 3 Flyout styles ([b60f376](https://github.com/unoplatform/Uno.Themes/commit/b60f3763a3a52aba9381590909e1082c4f2f5070))
* add more M3 implicit/shared styles ([9315afc](https://github.com/unoplatform/Uno.Themes/commit/9315afcb21e7f028ff635ad53817ba3cb65625e6))
* add style key aliases ([b223c4e](https://github.com/unoplatform/Uno.Themes/commit/b223c4e5d2056cd09200902a0c3c9e20b448bcc8))
* Add support for net6 mobile targets, bump to uno 4.2-dev ([c911f37](https://github.com/unoplatform/Uno.Themes/commit/c911f377e00d12f20660c48d6ccb8bc73d43a14b))