Toolbelt.Web.CssClassInlineBuilder 3.1.0.1

dotnet add package Toolbelt.Web.CssClassInlineBuilder --version 3.1.0.1                
NuGet\Install-Package Toolbelt.Web.CssClassInlineBuilder -Version 3.1.0.1                
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="Toolbelt.Web.CssClassInlineBuilder" Version="3.1.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Toolbelt.Web.CssClassInlineBuilder --version 3.1.0.1                
#r "nuget: Toolbelt.Web.CssClassInlineBuilder, 3.1.0.1"                
#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 Toolbelt.Web.CssClassInlineBuilder as a Cake Addin
#addin nuget:?package=Toolbelt.Web.CssClassInlineBuilder&version=3.1.0.1

// Install Toolbelt.Web.CssClassInlineBuilder as a Cake Tool
#tool nuget:?package=Toolbelt.Web.CssClassInlineBuilder&version=3.1.0.1                

CSS Class Inline Builder (designed for Blazor) NuGet Package unit tests

Summary

Build CSS class string for a "class" attribute dynamically based on the boolean switch and enum values in Razor files in-line.

fig1

How to use?

1. Install the package to your project.

Package Manager Console:

PM> Install-Package Toolbelt.Web.CssClassInlineBuilder

dotnet CLI:

$ dotnet add package Toolbelt.Web.CssClassInlineBuilder

2. Declare for using "CSS class inline builder".

Add @using static Toolbelt.Web.CssClassInlineBuilder.V2 declaration in the head of each .razor file where you want to use the CSS class inline builder.

Or you can also add the declaration to _Imports.razor once instead.

@using static Toolbelt.Web.CssClassInlineBuilder.V2

3. Use "CssClass(...)" method to build CSS class string!

You can use the CssClass(...) method anywhere you want to build a CSS class string.

3-1. CSS class name strings

Basically, you can pass CSS class name strings up to 4 to the arguments of CssClass() method.

The CssClass() method returns a string that is concatenated with all of those passed to argument strings with a space separator.

<div class="@CssClass("foo", "bar")">

3-2. objects which has bool properties

Next, you can pass objects (including anonymous types) up to 4 that contain bool properties to the arguments of the CssClass() method.

The CssClass() method picks up the bool properties where its value is true from the argument objects, concatenates those property's name strings with a space separator, and returns them. (The names of properties are converted to lowercase.)

<div class="@CssClass(new {Foo=true, Bar=false}, new {Fizz=true})">

As you know, the anonymous type can omit explicit property names when the name is the same as a variable name.

<div class="@CssClass(new {Foo, Bar}, new {Fizz})">

@code {
  private bool Foo = false;
  private bool Bar = true;
  private bool Fizz = true;
  ...

The property name will be converted from a camel/snake case naming convention to a hyphenated lowercase.

<div class="@CssClass(new {FizzBuzz})">

@code {
  private bool FizzBuzz = true;
  ...
3-3. any other type properties in an object

If you pass an object with non-boolean-type properties, a CSS class name will be built for each property.
That CSS class name will be concatenated with a hyphen of the property name and its value.

@code {
  private int Stars = 5;
  ...
}

<div class="@CssClass(new {NumberOfStars = this.Stars})">

3-4. enum values

You can also pass enum values up to 4 to the arguments of the CssClass() method.

The enum value will be converted to a string as a CSS class name.

The name of the enum value will be converted from camel case/snake case naming convention to hyphenated lower case.

@code {
  enum StateValues {
    NotReady,
    Complete,
    Error
  }

  private StateValues State = StateValues.NotReady;
  ...
}

<div class="@CssClass(this.State)">

Finally, you can mix those all!

You can pass mixing strings, objects, and enum values to the argument of the CssClass() method.

@code {
  enum StateValues {
    NotReady,
    Complete,
    Error
  }

  private bool Fizz = true;
  private bool Buzz = false;
  private int NumOfStars = 5;
  private StateValues State = StateValues.Complete;
  ...
}
...
<div class="@CssClass(new {Fizz, Buzz}, $"stars-{NumOfStars}", State)">

Notice

The CssClass() method uses the .NET CLR "Reflection" feature to parse the object's properties.

This means using the CssClass() method can degrade performance.

The CssClass() method includes a caching mechanism to avoid performance degradation, but it will be better to let you know this information anyway.

Release Notes

You can see the release notes here.

License

Mozilla Public License Version 2.0

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  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 is compatible.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net6.0

    • No dependencies.
  • net7.0

    • No dependencies.
  • net8.0

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Toolbelt.Web.CssClassInlineBuilder:

Package Downloads
BlazingStory

The clone of "Storybook" for Blazor, a frontend workshop for building UI components and pages in isolation.

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Toolbelt.Web.CssClassInlineBuilder:

Repository Stars
jsakamoto/awesome-blazor-browser
A Blazor WebAssembly app for browsing the "Awesome Blazor" resources.
Version Downloads Last updated
3.1.0.1 24,519 4/6/2024
3.1.0 131 4/6/2024
3.0.0 123 4/6/2024
2.0.0 39,161 6/20/2021
1.1.1 1,259 8/27/2020
1.1.0 882 5/6/2020
1.0.0.2 650 1/3/2020

v.3.1.0
- Mark as trimmable.


To see all the change logs, please visit the following URL.
- https://github.com/jsakamoto/CssClassInlineBuilder/blob/master/RELEASE-NOTES.txt