Skip to content

Commit

Permalink
fix(brush): rerender don't emit brush:end (#5053)
Browse files Browse the repository at this point in the history
  • Loading branch information
pearmini authored May 18, 2023
1 parent ab0ccf7 commit f07b512
Show file tree
Hide file tree
Showing 4 changed files with 106 additions and 3 deletions.
30 changes: 30 additions & 0 deletions __tests__/integration/api-chart-render-brush-end.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import { chartRenderBrushEnd as render } from '../plots/api/chart-render-brush-end';
import { createNodeGCanvas } from './utils/createNodeGCanvas';
import { sleep } from './utils/sleep';

describe('chart.render', () => {
const canvas = createNodeGCanvas(800, 500);

it('chart.render() should not emit brush:end', async () => {
const { rerendered, finished, button, chart } = render({
canvas,
container: document.createElement('div'),
});
await finished;
await sleep(20);

chart.off();
const fn = jest.fn();
chart.on('brush:end', () => {
fn();
});
button.dispatchEvent(new CustomEvent('click'));
await rerendered;
await sleep(20);
expect(fn).toBeCalledTimes(0);
});

afterAll(() => {
canvas?.destroy();
});
});
71 changes: 71 additions & 0 deletions __tests__/plots/api/chart-render-brush-end.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
import { Chart } from '../../../src';

export function chartRenderBrushEnd(context) {
const { container, canvas } = context;

// button
const button = document.createElement('button');
button.innerText = 'Render';
container.appendChild(button);

// wrapperDiv
const wrapperDiv = document.createElement('div');
container.appendChild(wrapperDiv);

const chart = new Chart({
theme: 'classic',
container: wrapperDiv,
paddingBottom: 120,
width: 1000,
canvas,
});

chart.data([
{ date: '2001-01', value: 100 },
{ date: '2001-02', value: 400 },
{ date: '2001-03', value: 500 },
{ date: '2001-04', value: 600 },
{ date: '2001-05', value: 300 },
{ date: '2001-06', value: 600 },
{ date: '2001-07', value: 300 },
{ date: '2001-08', value: 600 },
{ date: '2001-09', value: 109 },
{ date: '2001-10', value: 100 },
{ date: '2001-11', value: 102 },
{ date: '2001-12', value: 103 },
{ date: '2002-01', value: 102 },
{ date: '2002-02', value: 101 },
{ date: '2002-03', value: 200 },
{ date: '2002-04', value: 500 },
{ date: '2002-05', value: 100 },
{ date: '2002-06', value: 100 },
{ date: '2002-07', value: 102 },
{ date: '2002-08', value: 109 },
]);

chart
.interval()
.encode('x', 'date')
.encode('y', 'value')
.axis('x', { style: { labelTransform: 'rotate(90deg)' } })
.interaction('brushXHighlight', true);

const X = ['2001-01', '2001-03'];

chart.on('brush:end', () => console.log('brush:end'));

const finished = chart.render().then(() => {
chart.emit('brush:highlight', {
data: { selection: [X, [-Infinity, Infinity]] },
});
});

let resolve;
const rerendered = new Promise((r) => (resolve = r));

button.onclick = () => {
chart.render().then(resolve);
};

return { chart, button, finished, rerendered };
}
1 change: 1 addition & 0 deletions __tests__/plots/api/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,3 +23,4 @@ export { chartEmitPieTooltip } from './chart-emit-pie-tooltip';
export { chartRenderUpdateAttributes } from './chart-render-update-attributes';
export { chartRenderUpdateNonAnimation } from './chart-render-update-non-animation';
export { chartEmitBrushHighlightX } from './chart-emit-brush-highlight-x';
export { chartRenderBrushEnd } from './chart-render-brush-end';
7 changes: 4 additions & 3 deletions src/interaction/brushHighlight.ts
Original file line number Diff line number Diff line change
Expand Up @@ -302,7 +302,7 @@ export function brush(
};

// Remove mask and reset states.
const removeMask = () => {
const removeMask = (emit = true) => {
if (mask) mask.remove();
if (background) background.remove();
start = null;
Expand All @@ -311,7 +311,7 @@ export function brush(
creating = false;
mask = null;
background = null;
brushended();
if (emit) brushended();
};

// Update mask and invoke brushended callback.
Expand Down Expand Up @@ -480,7 +480,8 @@ export function brush(
if (mask) removeMask();
},
destroy() {
removeMask();
// Do not emit brush:end event.
if (mask) removeMask(false);
setCursor(root, 'default');
root.removeEventListener('dragstart', dragstart);
root.removeEventListener('drag', drag);
Expand Down

0 comments on commit f07b512

Please sign in to comment.