Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ipax77/pax.BlazorChartJs

Blazor ChartJs wrapper library
https://github.com/ipax77/pax.BlazorChartJs

blazor chartjs dotnet wrapper

Last synced: about 2 months ago
JSON representation

Blazor ChartJs wrapper library

Awesome Lists containing this project

README

        

![Nuget](https://img.shields.io/nuget/v/pax.BlazorChartJs)
[![Playwright Tests](https://github.com/ipax77/pax.BlazorChartJs/actions/workflows/pwtests.yml/badge.svg)](https://github.com/ipax77/pax.BlazorChartJs/actions/workflows/pwtests.yml) [TestPage](https://ipax77.github.io/pax.BlazorChartJs/)

# Blazor dotnet wrapper library for [ChartJs](https://github.com/chartjs/Chart.js)

The following versions of ChartJs are compatible with published releases of `pax.BlazorChartJs`
Release | ChartJs | Tests
---|---------------|---------------|
<= 0.5.0 | **3.9.1** | 3.9.1
>= 0.5.0 | **4.x** | 4.4.6


## Getting started
This library is using [JavaScript isolation](https://learn.microsoft.com/en-us/aspnet/core/blazor/javascript-interoperability/?view=aspnetcore-6.0#javascript-isolation-in-javascript-modules-1). JS isolation provides the following benefits:
* Imported JS no longer pollutes the global namespace.
* Consumers of a library and components aren't required to import the related JS.
## Prerequisites
* dotnet 6/7 for versions < 0.8
* dotnet 8 for versions >= 0.8
## Installation

**dotnet 8**
```
dotnet add package pax.BlazorChartJs
```

**dotnet 6/7**
```
dotnet add package pax.BlazorChartJs --version 0.6.3
```

Program.cs:
``` cs
builder.Services.AddChartJs(options =>
{
// default
options.ChartJsLocation = "https://cdn.jsdelivr.net/npm/chart.js";
options.ChartJsPluginDatalabelsLocation = "https://cdn.jsdelivr.net/npm/chartjs-plugin-datalabels@2";
});
```

## Usage

Sample Project [pax.BlazorChartJs.samplelib](https://github.com/ipax77/pax.BlazorChartJs/tree/master/src/pax.BlazorChartJs.samplelib) with
[Sample Chart](https://ipax77.github.io/pax.BlazorChartJs/minchart)
```razor
@using pax.BlazorChartJs


Randomize




@code {
ChartJsConfig chartJsConfig = null!;
ChartComponent? chartComponent;
private bool chartReady;

protected override void OnInitialized()
{
chartJsConfig = new ChartJsConfig()
{
Type = ChartType.bar,
Data = new ChartJsData()
{
Labels = ["Jan", "Feb", "Mar"],
Datasets = new List()
{
new BarDataset()
{
Label = "Dataset 1",
Data = [ 1, 2, 3 ]
}
}
}
};
base.OnInitialized();
}

private void ChartEventTriggered(ChartJsEvent chartJsEvent)
{
if (chartJsEvent is ChartJsInitEvent initEvent)
{
chartReady = true;
}
}

private void Randomize()
{
if (!chartReady)
{
return;
}

List updateDatasets = [];

foreach (var dataset in chartJsConfig.Data.Datasets)
{
if (dataset is BarDataset barDataset)
{
List newData = new();
foreach (var data in barDataset.Data)
{
newData.Add(Random.Shared.Next(1, 10));
}
barDataset.Data = newData;
updateDatasets.Add(dataset);
}
}
chartJsConfig.UpdateDatasetsSmooth(updateDatasets);
}
}
```

## Update Chart
* To update the chart with the current ChartJsConfig call ```ChartJsConfig.ReinitializeChart()```
* To update the chart with smooth animations there are several helper functions available, e.g.:
- ```ChartJsConfig.SetLabels(...)```
- ```ChartJsConfig.AddData(...)```
- ```ChartJsConfig.AddDatasetSmooth(...)```
- ```ChartJsConfig.SetData(...)```
* use ```ChartJsConfig.UpdateChartOptions()``` to update the chart options, only (e.g. [StepSize](https://github.com/ipax77/pax.BlazorChartJs/blob/master/src/pax.BlazorChartJs.samplelib/StackedChartComp.razor#L106))

## Chart Events
Several chart events are available, by default only the Init event is fired. The others can be activated in the ChartJsConfig.Options [Sample](https://github.com/ipax77/pax.BlazorChartJs/blob/master/src/pax.BlazorChartJs.samplelib/EventsComp.razor)
* click
* hover
* leave
* progress
* complete
* resize

## Supported Plugins
* [chartjs-plugin-datalabels](https://github.com/chartjs/chartjs-plugin-datalabels)
* [ArbitraryLines](https://www.youtube.com/watch?v=7ZZ_XfaJQbM&t=379s) (YouTube)
* Custom Plugins [Sample](https://github.com/ipax77/pax.BlazorChartJs/blob/master/src/pax.BlazorChartJs.samplelib/CustomPluginComp.razor)

## ChartComponent
Several chart functions are available in the ChartComponent, e.g.:
* ```ChartComponent.ResizeChart(...)```
* ```ChartComponent.GetChartImage(...)```
* ```ChartComponent.ToggleDataVisibility(...)```

## Contributing

We really like people helping us with the project. Nevertheless, take your time to read our contributing guidelines [here](https://github.com/ipax77/pax.BlazorChartJs/blob/master/CONTRIBUTING.md).

## ChangeLog

v0.8.5

>- Microsoft.AspNetCore.Components.Web v8.0.*
>- ChartJs v4.4.5 tests
>- Test/Sample projects update to dotnet v8.0.10

v0.8.4

>- Microsoft.AspNetCore.Components.Web v8.0.8
>- ChartJs v4.4.4 tests

v0.8.3

>- Microsoft.AspNetCore.Components.Web v8.0.2
>- Added ChartJsConfig.UpdateDatasetsSmooth updates the ChartJs dataset(s), instead of replacing.
>- Added BlazorLegendBase that can be used for a [ChartJs Html Legend](https://www.chartjs.org/docs/latest/samples/legend/html.html) - [Sample][https://ipax77.github.io/pax.BlazorChartJs/htmllegendchart]
>- Added ChartComponent.GetLegendItems()
>- Added ChartComponent.IsDatasetVisible(int datasetIndex)
>- Added ChartComponent.SetDatasetPointsActive(int datasetIndex)
>- BarDataset.BarPercentage changed from int? to double?
>- Renamed Layout to ChartJsLayout (CA1724)
>- `IndexableOption` now supports Collection Expressions e.g.
```csharp
BorderColor = ["rgba(255, 99, 132, 1)", "rgba(54, 162, 235, 1)"],
BorderWidth = [1, 2]
```
>- ChartJs v4.4.2 Tests
>- Blazor App sample

v0.8.2

>- ChartJs v4.4.1 tests
>- Catching (more) dispose exeptions when switching from SSR to CSR (rendermode auto - AggregateException, JSDisconnectedException)

v0.8.1

>- dotnet 8 **Breaking Change**
>- Added missing pie/doughnut dataset options (Cutout, Radius, Animation)
>- The `IndexableOption` now supports implicit operators, allowing a more concise syntax for initialization.

**New Syntax:**
```csharp
BorderColor = new List()
{
"rgba(255, 99, 132, 1)",
"rgba(54, 162, 235, 1)"
},
BorderWidth = 1
```

Old Syntax (still possible):
```csharp
BorderColor = new IndexableOption(new List()
{
"rgba(255, 99, 132, 1)",
"rgba(54, 162, 235, 1)"
}),
BorderWidth = new IndexableOption(1)
```

v0.6.3

>- Reverted Microsoft.TypeScript.MSBuild to v5.2.2
Microsoft.TypeScript.MSBuild v5.3.2 not working for Blazor projects (only working for wasm)

v0.6.2

>- Microsoft.AspNetCore.Components.Web upgrade to v6.0.25
>- Added missing pie/doughnut dataset options (Cutout, Radius, Animation)
>- The `IndexableOption` now supports implicit operators, allowing a more concise syntax for initialization.

**New Syntax:**
```csharp
BorderColor = new List()
{
"rgba(255, 99, 132, 1)",
"rgba(54, 162, 235, 1)"
},
BorderWidth = 1
```

Old Syntax (still possible):
```csharp
BorderColor = new IndexableOption(new List()
{
"rgba(255, 99, 132, 1)",
"rgba(54, 162, 235, 1)"
}),
BorderWidth = new IndexableOption(1)
```

v0.6.1

>- ChartJsLabelClickEvent and ChartJsLabelHoverEvent with 'nearest' DatasetLabel and DatasetIndex
>- Microsoft.AspNetCore.Components.Web upgrade to v6.0.21

v0.6.0

>- Fix typo for AngleLines in LinearRadialAxis **Breaking Change**

v0.5.2

>- Datalabels per dataset contributed by pjvinson
>- ChartJs v4.4.0 tests

v0.5.1

>- Marked ChartJsGrid border options as obsolete for v4.x - use ChartJsAxisBorder instead.
>- TimeSeriesAxis Min, Max, SuggestedMin and SuggestedMax are of type ```StringOrDoubleValue```, now.
>- Microsoft.AspNetCore.Components.Web upgrade to v6.0.16
>- ChartJs v4.3.0 tests
>- ChartJs v4.3.1 tests
>- ChartJs v4.3.3 tests

v0.5.0

>- **Breaking Changes**
>- Update to [ChartJs v4.x](https://www.chartjs.org/docs/latest/migration/v4-migration.html)
>- Removed ChartJs javascript files - defaults to cdn links, now. Use ``` options.ChartJsLocation = "mychart.js"``` to use a custom/local ChartJs version.
>- Removed chartjs-plugin-labels (you can still register it as [custom plugin](https://github.com/ipax77/pax.BlazorChartJs/blob/master/src/pax.BlazorChartJs.samplelib/CustomPluginComp.razor))
>- Microsoft.AspNetCore.Components.Web upgrade to v6.0.13
>- Added ScaleAxis X1 and Y1 (override ChartJsOptionsScales for other names)
>- ```ChartJsConfig.UpdateChartOptions()``` (will replace ```ChartComponent.UpdateChartOptions```)
>- ```ChartJsConfig.ReinitializeChart()``` (will replace ```ChartComponent.DrawChart```)