BlazorCommon 1.1.8

There is a newer version of this package available.
See the version list below for details.
dotnet add package BlazorCommon --version 1.1.8
                    
NuGet\Install-Package BlazorCommon -Version 1.1.8
                    
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="BlazorCommon" Version="1.1.8" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="BlazorCommon" Version="1.1.8" />
                    
Directory.Packages.props
<PackageReference Include="BlazorCommon" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add BlazorCommon --version 1.1.8
                    
#r "nuget: BlazorCommon, 1.1.8"
                    
#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.
#:package BlazorCommon@1.1.8
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=BlazorCommon&version=1.1.8
                    
Install as a Cake Addin
#tool nuget:?package=BlazorCommon&version=1.1.8
                    
Install as a Cake Tool

Getting Started Getting Started

What is BlazorCommon?

It is a set of Blazor components grouped in an RCL library with the purpose of speeding up the construction of applications and contributing to both own and collective knowledge.

Dependencies

In current version

  • net7.0 (For projects in .net 6 use Version 6.00)
  • ClosedXML (>= 0.100.3)
  • Microsoft.AspNetCore.Components .Web (>= 7.0.0)

How it works?

After installing the Nuget package we can start using the components in a Blazor project.

using BlazorCommon;
using BlazorCommon.Grid;
...

Grid

Grids are one of the most used components today, they are also one of the main headaches when it comes to maintaining the code. We present a simple and configurable option.

Getting Simple grid

How to implement it

Code behind

using BlazorCommon.Grid;
using BlazorCommon;
using Microsoft.AspNetCore.Components;

namespace BlazorCommonTester.Pages
{
    public class GridBase : HtmlComponentBase
    {
        protected GridConfigurationBase GridC { get; set; }
        protected override async Task OnInitializedAsync()
        {
            GridC = await GridConfigurationBase.GetInstanceAsync();
           await base.OnInitializedAsync();
        }

    }
}

Front

<BlazorCommon.Grid.Grid GridConfig="GridC"  />

If your practical interest is not to always present the same information about the last time an animal was sighted, all you have to do is overwrite the GetList() method of the QueryResultBase Class.

QueryResultBase Class

 public class QueryResultBase
    {
        public int NotFilteredTotal { get; set; }
        public int Total { get; set; }
        public IEnumerable<RowBase> List { get; set; }
        public int PageSize { get; set; }
        public int PageIndex { get; set; }
        public SortChangedEvent Sort { get; set; }

        public QueryResultBase()
        {
            PageSize = 10;
            PageIndex = 1;
        }

        public virtual void GetList()
        {
            List = Animal.GetAll();
        }

Note: The List property of the class derives from RowBase; Thus, for everything to go well, the class that makes up the list must derive from this class.

 public IEnumerable<RowBase> List { get; set; } // Property of QueryResultBase
   public class RowBase
    {
        public string RowBaseBackGroundColor { get; set; }
        public string RowBaseFontColor { get; set; }
        public string RowBaseId { get; set; }
        public bool RowBaseSelected { get; set; }
        public bool RowBasePreviousSelected { get; set; }
        public bool RowBaseVisible { get; set; }
        public List<ExpandedRowOption> ExpandedRowOptions { get; set; }
        public bool RowExpanded { get; set; }

        public RowBase()
        {
            RowBaseBackGroundColor = "white";
            RowBaseFontColor = "black";
            Random r = new Random();
            int rInt = r.Next(0, 100000000);
            RowBaseId = $"row_{rInt}";
            RowBaseVisible= true;
        }

        public virtual void SetExpandedRowOptions()
        {
            ExpandedRowOptions = Enum.GetValues(typeof(ExpandedRowOption)).Cast<ExpandedRowOption>().ToList();
        }

        public virtual async Task OnRowClick(JsHelper jsHelper)
        {
            RowExpanded = !RowExpanded;
            if(RowExpanded)
            {
                SetExpandedRowOptions();
                await jsHelper.SetSessionStorage("row", this);
            }
            else
            {
                await jsHelper.RemoveSessionStorage("row");
            }
        }

    }

The RowBase class determines the behavior and appearance of rows within the table, so the list received by the grid must inherit from it.

 public class MyList: RowBase
    {
       ...
    }
Filters

By default the grid implements the filters and the ordering of all its columns. This can be changed using a class derived from GridColumnBase. This in turn is initialized from GridConfigurationBase, which is finally the object that we pass as a parameter to the component.

Getting filter grid


  public virtual List<GridColumnBase> GetGridColumnBase()
        {
            List<PropertyInfo> baseProperties = new RowBase().GetType().GetProperties().ToList();
            List<PropertyInfo> props = ItemType.GetProperties().Where(x => !baseProperties.Any(s => s.Name == x.Name)).ToList();

           return props.Select(x => new GridColumnBase(x, props.IndexOf(x), KeyColumn)).ToList();
        }

// And GridColumnBase constructor

 public GridColumnBase(PropertyInfo prop, int position, string keyColumnName, bool searchable =true, bool sortable= true)
        {
            ...
        }

Summary

As you can see, it is enough to change the data source and that the objects in this list belong to a class derived from RowBase. There are many things that can be configured. We invite you to explore the complete code of the project in GitHub.

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

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
1.3.5 222 2/23/2024
1.3.4 248 1/2/2024
1.3.1 279 5/30/2023
1.3.0 286 4/20/2023
1.2.9 265 4/16/2023
1.2.8 284 4/16/2023
1.2.7 279 4/16/2023
1.2.6 335 3/14/2023
1.2.5 291 3/13/2023
1.2.4 312 3/13/2023
1.2.3 330 3/13/2023
1.2.2 310 3/13/2023
1.2.1 338 3/10/2023
1.2.0 301 3/10/2023
1.1.9 331 3/7/2023
1.1.8 320 3/7/2023
1.1.7 297 3/7/2023
1.1.6 340 3/5/2023
1.1.5 328 3/4/2023
1.1.4 329 3/3/2023
1.1.3 334 3/2/2023
1.1.2 371 2/28/2023
1.1.1 321 2/28/2023
1.1.0 334 2/28/2023
1.0.9 346 2/27/2023
1.0.8 358 2/27/2023
1.0.5 341 2/25/2023
1.0.4 325 2/24/2023
1.0.3 354 2/19/2023
1.0.2 349 2/18/2023
1.0.1 340 2/17/2023

Search box issues and improvements