Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

ChartJS on click to get label #351

Answered by cooperRjp
cooperRjp asked this question in Q&A
Discussion options

using the bar chart i'm trying to get the label value of the bar which is clicked. I've looked at the docs on chart.js and they have this method:

function clickHandler(evt) {
    const points = myChart.getElementsAtEventForMode(evt, 'nearest', { intersect: true }, true);

    if (points.length) {
        const firstPoint = points[0];
        var label = myChart.data.labels[firstPoint.index];
        var value = myChart.data.datasets[firstPoint.datasetIndex].data[firstPoint.index];
    }
} 

and as an option on CChart i can pass an on click event as a option, but i'm struggling to get the value.

<CChart
    type="bar"
    height={120}
    data={{
        labels: dispatchDate,
        datasets: [
            {
                label: 'Number of Products',
                backgroundColor: 'blue',
                data: numberOfProducts,
            },
        ],
    }}
    options=
    {{
        onClick: (e) => {
            const points = this.getElementsAtEventForMode(e, 'nearest', { intersect: true }, true);
  
            if (points.length) {
                const firstPoint = points[0];
                var label = myChart.data.labels[firstPoint.index];
                var value = myChart.data.datasets[firstPoint.datasetIndex].data[firstPoint.index];
  
                console.log(label);
            }
  
  
        }
    }}
  />
You must be logged in to vote

Just worked it out, here is the code if you are looking to do the same.

 <CChart
    type="bar"
    height={120}
    data={{
        labels: dispatchDate,
        datasets: [
            {
                label: 'Number of Products',
                backgroundColor: 'blue',
                data: numberOfProducts,
            },
        ],
    }}
    options=
    {{
        onClick: (e) => {
  
            var points = e.chart.getElementsAtEventForMode(e, 'nearest', { intersect: true }, true)
  
            if (points.length) {
                const firstPoint = points[0];
                var label = e.chart.data.labels[firstPoint.index];
                var value = e.chart.data.datasets[f…

Replies: 1 comment

Comment options

Just worked it out, here is the code if you are looking to do the same.

 <CChart
    type="bar"
    height={120}
    data={{
        labels: dispatchDate,
        datasets: [
            {
                label: 'Number of Products',
                backgroundColor: 'blue',
                data: numberOfProducts,
            },
        ],
    }}
    options=
    {{
        onClick: (e) => {
  
            var points = e.chart.getElementsAtEventForMode(e, 'nearest', { intersect: true }, true)
  
            if (points.length) {
                const firstPoint = points[0];
                var label = e.chart.data.labels[firstPoint.index];
                var value = e.chart.data.datasets[firstPoint.datasetIndex].data[firstPoint.index];
            }
  
            console.log(label);
  
        }
    }}
  />
You must be logged in to vote
0 replies
Answer selected by mrholek
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Category
🙏
Q&A
Labels
None yet
1 participant
Morty Proxy This is a proxified and sanitized view of the page, visit original site.