Security News
CISA Brings KEV Data to GitHub
CISA's KEV data is now on GitHub, offering easier access, API integration, commit history tracking, and automated updates for security teams and researchers.
chartjs-plugin-dragdata
Advanced tools
A plugin for Chart.js >= 2.4.0
Makes data points draggable. Supports touch events.
Online demo single Y-Axis, dual Y-Axis,small chart,bubble chart,radar chart
npm install chartjs-plugin-dragdata --save
In browsers, you may use the following script tag:
<script src="https://cdn.jsdelivr.net/npm/chartjs-plugin-dragdata@0.3.0/dist/chartjs-plugin-dragData.min.js"></script>
Or, download a release archive file from the dist folder.
To make (line, bubble and radar chart) data points draggable, simply add dragData: true
to the config section of the chart instance. If you (additionally to the y-axis) would like to drag data along the x-axis, you may also add dragX: true
.
To round the values dragged to, simply add dragDataRound: 0
to the config section of the chart instance.
0
will round to ..., -2, -1, 0, 1, 2, ...
1
will round to ..., -0.2, -0.1, 0.0, 0.1, 0.2, ...
-1
will round to ..., -20, -10, 0, 10, 20, ...
Individual event listeners can be specified as follows:
{
...
dragData: true,
dragX: false,
dragDataRound: 0,
onDragStart: function (event, element) {},
onDrag: function (event, datasetIndex, index, value) {},
onDragEnd: function (event, datasetIndex, index, value) {}
}
Minimum and maximum allowed data values can be specified through the min
and max
ticks settings in the scales options. By setting these values accordingly, unexptected (fast) changes to the scales, that may occur when dragging data points towards the outer boundaries of the y-axis, can be prohibited.
options: {
scales: {
yAxes: [{
ticks: {
max: 25,
min: 0
}
}]
},
...
To avoid dragging specific datasets, you can set dragData to false within the dataset options.
const data = {
datasets: [
{
label: "Data Label",
fill: false,
data: dataPoints,
yAxisID: 'B',
dragData: false
}, {
...
To avoid dragging specific scales, you can set dragData to false within the axis scale options.
options: {
scales: {
yAxes: [{
ticks: {
max: 25,
min: 0
},
dragData: false
}]
},
...
To avoid dragging specific data points inside a draggable dataset, you can return false
to function onDragStart
.
To disable the automatic update of the data, you can return false
to function onDrag
. Nothing will happen to the points without you changing the data
attribute somewhere else. This is use full for frameworks like emberjs who us the data down action up paradigm.
When working with a module bundler (e.g. Webpack) and a framework (e.g. Vue.js/React/Angular), you still need to import the plugin library after installing. Here's a small example for a Vue.js component
<template>
<div>
<canvas id="chart"></canvas>
</div>
</template>
<script>
import Chart from 'chart.js'
// load the options file externally for better readability of the component.
// In the chartOptions object, make sure to add "dragData: true" etc.
import chartOptions from '~/assets/js/labour.js'
import 'chartjs-plugin-dragdata'
export default {
data() {
return {
chartOptions
}
},
mounted() {
this.createChart('chart', this.chartOptions)
},
methods: {
createChart(chartId, chartData) {
const ctx = document.getElementById(chartId)
const myChart = new Chart(ctx, {
type: chartData.type,
data: chartData.data,
options: chartData.options,
})
}
}
}
</script>
<style>
</style>
Please feel free to submit an issue or a pull request!
chartjs-plugin-dragdata.js is available under the MIT license.
FAQs
Draggable data points for Chart.js
The npm package chartjs-plugin-dragdata receives a total of 9,314 weekly downloads. As such, chartjs-plugin-dragdata popularity was classified as popular.
We found that chartjs-plugin-dragdata demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
CISA's KEV data is now on GitHub, offering easier access, API integration, commit history tracking, and automated updates for security teams and researchers.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.