Skip to content

Commit

Permalink
#10070 - Fix: Scroll bars for legend widgets won't move coherently wi…
Browse files Browse the repository at this point in the history
…th displayed data (#10329) (#10332)

(cherry picked from commit 3234b9a)
  • Loading branch information
dsuren1 authored May 16, 2024
1 parent 9126955 commit 144ebdf
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 2 deletions.
4 changes: 2 additions & 2 deletions web/client/components/charts/WidgetChart.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import {
enableBarChartStack,
FONT
} from '../../utils/WidgetsUtils';

import withLegendScrollHandler from './withLegendScrollHandler';
const Plot = React.lazy(() => import('./PlotlyChart'));

const processDataProperties = (formula, key, data) => {
Expand Down Expand Up @@ -698,4 +698,4 @@ function WidgetChart({
);
}

export default withClassifyGeoJSONSync(WidgetChart);
export default withLegendScrollHandler(withClassifyGeoJSONSync(WidgetChart));
61 changes: 61 additions & 0 deletions web/client/components/charts/withLegendScrollHandler.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@

import React from 'react';
import isNil from 'lodash/isNil';

/**
* Handler to deal with legend mouse wheel sensitivity issue
* with chart widget has multiple legend items
* NOTE: This is a workaround for issue in plotly.js https://github.com/plotly/plotly.js/issues/6737
* until fix on plotly is implemented
*/
const withLegendScrollHandler = (WrappedComponent) => {
return (props) => {
/**
* Event listener captures mouse wheel event of legend element
* and modifies the deltaY such that the sensitivity is exhibited in a controlled manner
*/
const legendMouseWheelEventHandler = (graphDiv) => {
const legend = graphDiv.querySelector('.infolayer .legend');
if (legend) {
const legendBg = legend.querySelector('.bg');

// add listener in capture mode
legend.addEventListener('wheel', function(event) {
if (!event.isTrusted) return;
event.preventDefault();
event.stopPropagation();

const maxScrollDistance = legend.getBBox()?.height;
const scrollHeight = legendBg?.getBBox()?.height;

let deltaY = 0.30; // fallback fixed value
if (!isNil(scrollHeight) && !isNil(maxScrollDistance)) {
deltaY = (scrollHeight / maxScrollDistance) * 100;
}
if (Number(event.deltaY) < 0) {
deltaY *= -1; // negate on upward scroll
}
const newEvent = new WheelEvent('wheel', {
clientX: event.clientX,
clientY: event.clientY,
deltaY,
view: window,
bubbles: true,
cancelable: true
});
event.target.dispatchEvent(newEvent);
}, true);
}
};
return (
<WrappedComponent
{...props}
onInitialized={(figure, graphDiv) => {
legendMouseWheelEventHandler(graphDiv);
props.onInitialized(figure, graphDiv);
}}
/>);
};
};

export default withLegendScrollHandler;

0 comments on commit 144ebdf

Please sign in to comment.