Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/ipax77/pax.BlazorChartJs
- Owner: ipax77
- License: mit
- Created: 2022-08-14T11:19:01.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2024-11-01T06:59:05.000Z (2 months ago)
- Last Synced: 2024-11-01T07:26:38.920Z (2 months ago)
- Topics: blazor, chartjs, dotnet, wrapper
- Language: C#
- Homepage:
- Size: 77.8 MB
- Stars: 30
- Watchers: 1
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
- awesome - pax.BlazorChartJs - us/aspnet/core/blazor/javascript-interoperability/?view=aspnetcore-6.0#javascript-isolation-in-javascript-modules-1)) (Integrations / Others)
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.10v0.8.4
>- Microsoft.AspNetCore.Components.Web v8.0.8
>- ChartJs v4.4.4 testsv0.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 samplev0.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.21v0.6.0
>- Fix typo for AngleLines in LinearRadialAxis **Breaking Change**
v0.5.2
>- Datalabels per dataset contributed by pjvinson
>- ChartJs v4.4.0 testsv0.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 testsv0.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```)