pax.BlazorChartJs
0.5.0-rc1.0
See the version list below for details.
dotnet add package pax.BlazorChartJs --version 0.5.0-rc1.0
NuGet\Install-Package pax.BlazorChartJs -Version 0.5.0-rc1.0
<PackageReference Include="pax.BlazorChartJs" Version="0.5.0-rc1.0" />
paket add pax.BlazorChartJs --version 0.5.0-rc1.0
#r "nuget: pax.BlazorChartJs, 0.5.0-rc1.0"
// Install pax.BlazorChartJs as a Cake Addin #addin nuget:?package=pax.BlazorChartJs&version=0.5.0-rc1.0&prerelease // Install pax.BlazorChartJs as a Cake Tool #tool nuget:?package=pax.BlazorChartJs&version=0.5.0-rc1.0&prerelease
Blazor dotnet wrapper library for ChartJs
- >= v0.5 ⇒ ChartJs v4.x - Tested with version 4.2.0
- < v0.5 ⇒ ChartJs v3.91
Getting started
Prerequisites
dotnet 6
Installation
dotnet add package pax.BlazorChartJs
Program.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
<div class="btn-group">
<button type="button" class="btn btn-primary" @onclick="Randomize">Randomize</button>
<button type="button" class="btn btn-primary" @onclick="AddDataset">Add Dataset</button>
<button type="button" class="btn btn-primary" @onclick="AddData">Add Data</button>
<button type="button" class="btn btn-primary" @onclick="RemoveLastDataset">Remove Dataset</button>
<button type="button" class="btn btn-primary" @onclick="RemoveLastDataFromDatasets">Remove Data</button>
</div>
<div class="w-75 h-50">
<ChartComponent @ref="chartComponent" OnEventTriggered="LabelClicked" ChartJsConfig="chartJsConfig"></ChartComponent>
</div>
<div>
@if (!String.IsNullOrEmpty(labelClicked))
{
<p>
Label clicked: @labelClicked
</p>
}
</div>
@code {
ChartComponent? chartComponent;
ChartJsConfig chartJsConfig = null!;
private string? labelClicked;
protected override void OnInitialized()
{
chartJsConfig = new()
{
Type = ChartType.bar,
Data = new ChartJsData()
{
Labels = new List<string>()
{
"Red", "Blue", "Yellow", "Green", "Purple", "Orange"
},
Datasets = new List<ChartJsDataset>()
{
new BarDataset()
{
Label = "# of Votes",
Data = new List<object>() { 12, 19, 3, 5, 2, 3 },
BackgroundColor = new IndexableOption<string>(new List<string>()
{
"rgba(255, 99, 132, 0.2)",
"rgba(54, 162, 235, 0.2)",
"rgba(255, 206, 86, 0.2)",
"rgba(75, 192, 192, 0.2)",
"rgba(153, 102, 255, 0.2)",
"rgba(255, 159, 64, 0.2)",
}),
BorderColor = new IndexableOption<string>(new List<string>()
{
"rgba(255, 99, 132, 1)",
"rgba(54, 162, 235, 1)",
"rgba(255, 206, 86, 1)",
"rgba(75, 192, 192, 1)",
"rgba(153, 102, 255, 1)",
"rgba(255, 159, 64, 1)",
}),
BorderWidth = new IndexableOption<double>(1)
}
}
},
Options = new ChartJsOptions()
{
Responsive = true,
MaintainAspectRatio = true,
OnClickEvent = true,
Scales = new ChartJsOptionsScales()
{
Y = new LinearAxis()
{
SuggestedMax = 25
}
}
}
};
base.OnInitialized();
}
private void ShowChart()
{
chartComponent?.DrawChart();
}
private void LabelClicked(ChartJsEvent chartJsEvent)
{
if (chartJsEvent is ChartJsLabelClickEvent labelClickEvent)
{
labelClicked = labelClickEvent.Label;
}
}
private void AddData()
{
var dataAddEventArgs = ChartUtils.GetRandomData(chartJsConfig.Data.Datasets.Count);
Dictionary<ChartJsDataset, AddDataObject> datas = new();
for (int i = 0; i < chartJsConfig.Data.Datasets.Count; i++)
{
ChartJsDataset dataset = chartJsConfig.Data.Datasets[i];
datas.Add(dataset,
new AddDataObject(dataAddEventArgs.Data[i],
null,
dataAddEventArgs.BackgroundColors?[i],
dataAddEventArgs.BorderColors?[i]));
}
chartJsConfig.AddData(dataAddEventArgs.Label, null, datas);
}
private void Randomize()
{
var data = ChartUtils.GetRandomData(chartJsConfig.Data.Datasets.Count,
chartJsConfig.Data.Labels.Count, -100, 100);
Dictionary<ChartJsDataset, SetDataObject> chartData = new();
for (int i = 0; i < chartJsConfig.Data.Datasets.Count; i++)
{
var dataset = chartJsConfig.Data.Datasets.ElementAt(i);
var dataList = data.ElementAt(i);
chartData.Add(dataset, new SetDataObject(dataList));
}
chartJsConfig.SetData(chartData);
}
private void AddDataset()
{
var dataset = ChartUtils
.GetRandomDataset(chartJsConfig.Type == null ? ChartType.bar : chartJsConfig.Type.Value,
chartJsConfig.Data.Datasets.Count + 1,
chartJsConfig.Data.Labels.Count);
chartJsConfig.AddDataset(dataset);
}
private void RemoveLastDataset()
{
if (chartJsConfig.Data.Datasets.Any())
{
chartJsConfig.RemoveDataset(chartJsConfig.Data.Datasets.Last());
}
}
private void RemoveLastDataFromDatasets()
{
chartJsConfig.RemoveData();
}
Supported Plugins
- chartjs-plugin-datalabels
- ArbitraryLines (YouTube)
- Custom Plugins Sample
Known Limitations / ToDo
- Callbacks
- InteractionModes
- DataDecimation
ChangeLog
<details open="open"><summary>v0.5.0-rc1.0</summary>
- Breaking Changes
- Update to ChartJs v4.x
- Removed ChartJs javascript files - defaults to cdn links, now. Use
options.ChartJsLocation = "mychart.js"
if you want to use your projects ChartJs version.- Removed chartjs-plugin-labels (you can still register it as custom plugin)
- Microsoft.AspNetCore.Components.Web upgrade to v6.0.13
</details>
<details><summary>v0.4.1</summary>
- Catch ObjectDisposedException and JSException when disposing the ChartComponent while initializing
- Microsoft.AspNetCore.Components.Web upgrade to v6.0.12
</details>
<details><summary>v0.4.0</summary>
- Title.Text is now IndexableOptions<string> - Breaking Change!
- chartComponent?.DrawChart() triggeres an InitEvent after the chart is complete
- ChartJsInitEvent does have the ChartJsConfigGuid set correctly, now
- RemoveDataset(s) can now handle self referencing and missing
</details>
<details><summary>v0.3.5</summary>
- TimeCartesianAxisTicks fix
- Interactions fix
- Playwright tests
- ghpages
- ChartComponent DisposeAsync
</details>
<details><summary>v0.3.4</summary>
- Fix #7 - Axis Ticks JsonConverter
- Added ChartJsInitEvent which is triggered when the chart finished initializing the first time
- StackedChart Sample
</details>
<details><summary>v0.3.3</summary>
- Fix #6
- chartComponent.UpdateChartDatasets removed - use chartConfig.SetDatasets() instead
- Added Hidden option for Datasets
</details>
<details><summary>v0.3.2</summary>
- Chart update refactoring - Breaking Changes!
- Chart events refactoring - Breaking Changes!
- Typescript
- NuGet udpates
</details>
<details><summary>v0.3.1</summary>
- Time Scale Chart
- Optional javascript location options
- ChartJs API calls
- bugfixes
- refactoring
</details>
<details><summary>v0.3.0</summary>
- IndexableOption - Breaking Change!
</details>
<details><summary>v0.2.0</summary>
- Events
- Custom Plugin Sample
- ChartJs API calls
</details>
<details><summary>v0.1.3</summary>
- Nuget Package
</details>
<details><summary>v0.1.2</summary>
- RadarChart
</details>
<details><summary>v0.1.1</summary>
- Readme
</details>
<details><summary>v0.1.0</summary>
- Init
</details>
Product | Versions 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 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. 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. |
-
net6.0
- Microsoft.AspNetCore.Components.Web (>= 6.0.13)
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 | |
---|---|---|---|
0.8.5 | 508 | 10/19/2024 | |
0.8.4 | 623 | 8/24/2024 | |
0.8.3 | 1,851 | 3/4/2024 | |
0.8.3-rc1 | 96 | 2/29/2024 | |
0.8.2 | 1,209 | 12/6/2023 | |
0.8.1 | 216 | 11/28/2023 | |
0.8.0 | 154 | 11/28/2023 | |
0.8.0-rc2.0 | 88 | 11/15/2023 | |
0.8.0-rc1.0 | 97 | 10/17/2023 | |
0.6.3 | 262 | 11/28/2023 | |
0.6.2 | 147 | 11/28/2023 | |
0.6.1 | 2,076 | 9/11/2023 | |
0.6.0 | 608 | 8/28/2023 | |
0.5.2 | 151 | 8/25/2023 | |
0.5.1 | 1,480 | 4/28/2023 | |
0.5.0 | 4,240 | 2/4/2023 | |
0.5.0-rc2.0 | 116 | 2/3/2023 | |
0.5.0-rc1.0 | 111 | 2/3/2023 | |
0.4.1 | 643 | 1/8/2023 | |
0.4.0 | 650 | 11/4/2022 | |
0.3.5 | 502 | 10/13/2022 | |
0.3.4 | 1,567 | 9/30/2022 | |
0.3.3 | 429 | 9/28/2022 | |
0.3.2 | 470 | 9/15/2022 | |
0.3.1 | 416 | 9/10/2022 | |
0.3.0 | 419 | 9/6/2022 | |
0.2.0 | 418 | 9/5/2022 | |
0.1.3 | 437 | 8/31/2022 |