# Events

This plugin currently supports the following label events:

Name Chart events1 Description
enter mousemove the mouse is moved over a label
leave mousemove the mouse is moved out of a label
click click the mouse's primary button is pressed and released on a label

TIP

1 Chart.js events (opens new window) that need to be enabled in order to get the associated label event working. Note that by default Chart.js enables "mousemove", "mouseout", "click", "touchstart", "touchmove", "touchend", meaning that label events work out-of-the-box.

# Listeners

The listeners option allows to register callbacks to be notified when an event is detected on a specific label. This option is an object where each property represents an event, the key being the type of the event to listen and the value being a callback accepting the context and event arguments.

The context contains the same information as for scriptable options, can be modified (e.g. add new properties) and thus, if the callback explicitly returns true, the label is updated with the new context and the chart re-rendered. This allows to implement visual interactions with labels such as highlight, selection, etc.

Listeners can be registered for any label (options.plugin.datalabels.listener.*) or for labels of a specific dataset (dataset.datalabels.listeners.*).

TIP

If no listener is registered, incoming events are immediately ignored, preventing extra computation such as intersecting label bounding box. That means there should be no performance penalty for configurations that don't use events.

# Example

{
  data: {
    datasets: [{
      datalabels: {
        listeners: {
          click: function(context, event) {
            // Receives `click` events only for labels of the first dataset.
            // The clicked label index is available in `context.dataIndex`.
            console.log('label ' + context.dataIndex + ' has been clicked!');
            console.log('mouse is at position x:', event.x, 'and y:', event.y);

            if (event.native.ctrlKey) {
              console.log('control key is pressed!');
            }
          }
        }
      }
    }, {
        //...
    }]
  },
  options: {
    plugins: {
      datalabels: {
        listeners: {
          enter: function(context, event) {
            // Receives `enter` events for any labels of any dataset. Indices of the
            // clicked label are: `context.datasetIndex` and `context.dataIndex`.
            // For example, we can modify keep track of the hovered state and
            // return `true` to update the label and re-render the chart.
            context.hovered = true;
            return true;
          },
          leave: function(context, event) {
            // Receives `leave` events for any labels of any dataset.
            context.hovered = false;
            return true;
          }
        },
        color: function(context) {
          // Change the label text color based on our new `hovered` context value.
          return context.hovered ? "blue" : "gray";
        }
      }
    }
  }
}