From b9b516595572bfcd2883698d4272f050d76340e9 Mon Sep 17 00:00:00 2001 From: Tuukka Ikkala <10980802+ikkala@users.noreply.github.com> Date: Fri, 14 Jul 2023 10:50:13 +0300 Subject: [PATCH] Don't trigger the zoom on legends area Fixes chartjs#256 --- src/handlers.js | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/handlers.js b/src/handlers.js index af1e63ae..5d699f5c 100644 --- a/src/handlers.js +++ b/src/handlers.js @@ -1,6 +1,6 @@ import {directionEnabled, debounce, keyNotPressed, getModifierKey, keyPressed} from './utils'; import {zoom, zoomRect} from './core'; -import {callback as call, getRelativePosition} from 'chart.js/helpers'; +import {callback as call, getRelativePosition, _isPointInArea} from 'chart.js/helpers'; import {getState} from './state'; function removeHandler(chart, type) { @@ -58,6 +58,12 @@ function zoomStart(chart, event, zoomOptions) { } export function mouseDown(chart, event) { + const rect = event.target.getBoundingClientRect(); + const offsetX = event.clientX - rect.left; + const offsetY = event.clientY - rect.top; + if (chart.legend && _isPointInArea({x: offsetX, y: offsetY}, chart.legend)) { + return; + } const state = getState(chart); const {pan: panOptions, zoom: zoomOptions = {}} = state.options; if (