ChartJS widget
The ChartJS widget renders a chart by leveraging the open-source library chartjs.org (opens in a new tab).
Test in Kitchen Sink (opens in a new tab)
Basic example
The primary property required for ChartJs widget requires is config
.
source
View:
body:
Column:
children:
- ChartJs:
config: |
{
"type": "pie",
"data": {
"labels": ["Red", "Blue", "Yellow"],
"datasets": [{
"data": [300, 50, 100],
"backgroundColor": [
"rgb(255, 99, 132)",
"rgb(54, 162, 235)",
"rgb(255, 205, 86)"
]
}]
}
}
💡
Prompt ChatGPT to generate this configuration. E.g. What is the json configuration for pie chart using chartjs?
Update chart with new data points
You can append new data points to an existing chart:
- Add an id to your chart widget.
- Use
addLabels
andaddData
to add new data points. - Use
update
to redraw the chart.
source
View:
body:
Column:
styles:
gap: 16
padding: 24
children:
- Button:
label: Add Data
onTap:
executeCode:
body: |
testLineChart.addLabels(['July','August','September']);
testLineChart.addData(0,[20,30,40]);
testLineChart.addData(1,[5,45,25]);
testLineChart.update();
- ChartJs:
id: testLineChart
styles:
width: ${device.width}
config: |
{
type: 'line',
data: {
labels: [
'January',
'February',
'March',
'April',
'May',
'June'
],
datasets: [
{
label: 'My First dataset',
backgroundColor: [
'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: [
'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: 1,
data: [0, 10, 5, 2, 20, 45],
fill: 'start'
},{
label: 'My Second dataset',
backgroundColor: [
'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: [
'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: 1,
data: [5, 12, 7, 0, 18, 25],
fill: 'start'
}
]
},
options: {
scales: {
x: {
ticks: {
maxRotation: 0,
minRotation: 0
}
}
},
plugins: {
filler: {
propagate: false,
}
},
interaction: {
intersect: false,
},
tension: 0.4
}
}
Properties
Property | Type | Description |
---|---|---|
id | string | Assign an id to the chart so that you can run its methods |
config | object | Chart's configuration that conforms to chartjs.org (opens in a new tab) specification |
Styles
Property | Type | Description |
---|---|---|
width | integer | The width property determines the horizontal size of an element, allowing control over its width dimension within the layout. |
height | integer | The height property determines the vertical size of an element, allowing control over its height dimension within the layout. |
Methods
addLabels
This method adds labels to the x-axis of the chart.
Parameters:
- labels (array): An array of strings representing the labels for the chart.
Example:
myChart.addLabels(["January", "February", "March"]);
addData
This method appends data to an existing dataset.
Parameters:
- datasetIndex (integer): The index of the dataset to which the data should be added.
- data (array): An array of data points to add to the chart.
Example:
myChart.addData(0, [10, 20, 30]);
update
This method updates the chart to reflect any changes in data, labels, or configurations.
Example:
myChart.update();