From 30d1c1cc019f908d23eeaa1e7abe6afc1c8c12f7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E4=BA=8C=E8=B4=A7=E6=9C=BA=E5=99=A8=E4=BA=BA?= Date: Tue, 23 Jul 2024 21:45:38 +0800 Subject: [PATCH] fix: drag out and back should trigger --- docs/examples/editable.tsx | 6 ++++++ src/hooks/useDrag.ts | 18 ++++++++---------- tests/Range.test.tsx | 37 +++++++++++++++++++++++++++++++++---- 3 files changed, 47 insertions(+), 14 deletions(-) diff --git a/docs/examples/editable.tsx b/docs/examples/editable.tsx index 55dd11e98..ba03673c4 100644 --- a/docs/examples/editable.tsx +++ b/docs/examples/editable.tsx @@ -33,6 +33,12 @@ export default () => { onChangeComplete={(nextValue) => { console.log('Complete', nextValue); }} + // handleRender={(ori, handleProps) => { + // if (handleProps.index === 0) { + // console.log('handleRender', ori, handleProps); + // } + // return ori; + // }} styles={{ rail: { background: `linear-gradient(to right, blue, red)`, diff --git a/src/hooks/useDrag.ts b/src/hooks/useDrag.ts index 515e74cad..ac57eea4a 100644 --- a/src/hooks/useDrag.ts +++ b/src/hooks/useDrag.ts @@ -59,18 +59,16 @@ function useDrag( const flushValues = (nextValues: number[], nextValue?: number, deleteMark?: boolean) => { // Perf: Only update state when value changed - if (cacheValues.some((val, i) => val !== nextValues[i]) || deleteMark) { - if (nextValue !== undefined) { - setDraggingValue(nextValue); - } - setCacheValues(nextValues); + if (nextValue !== undefined) { + setDraggingValue(nextValue); + } + setCacheValues(nextValues); - let changeValues = nextValues; - if (deleteMark) { - changeValues = nextValues.filter((_, i) => i !== draggingIndex); - } - triggerChange(changeValues); + let changeValues = nextValues; + if (deleteMark) { + changeValues = nextValues.filter((_, i) => i !== draggingIndex); } + triggerChange(changeValues); }; const updateCacheValue = useEvent( diff --git a/tests/Range.test.tsx b/tests/Range.test.tsx index 616a3465f..371333d2c 100644 --- a/tests/Range.test.tsx +++ b/tests/Range.test.tsx @@ -53,6 +53,13 @@ describe('Range', () => { } } + function doMouseDrag(end: number) { + const mouseMove = createEvent.mouseMove(document); + (mouseMove as any).pageX = end; + (mouseMove as any).pageY = end; + fireEvent(document, mouseMove); + } + function doMouseMove( container: HTMLElement, start: number, @@ -62,10 +69,7 @@ describe('Range', () => { doMouseDown(container, start, element); // Drag - const mouseMove = createEvent.mouseMove(document); - (mouseMove as any).pageX = end; - (mouseMove as any).pageY = end; - fireEvent(document, mouseMove); + doMouseDrag(end); } function doTouchMove( @@ -695,6 +699,31 @@ describe('Range', () => { expect(onChangeComplete).toHaveBeenCalledWith([50, 100]); }); + it('out and back', () => { + const onChange = jest.fn(); + const onChangeComplete = jest.fn(); + const { container } = render( + , + ); + + doMouseMove(container, 0, 1000); + expect(onChange).toHaveBeenCalledWith([50]); + + doMouseDrag(0); + expect(onChange).toHaveBeenCalledWith([0, 50]); + + // Fire mouse up + fireEvent.mouseUp(container.querySelector('.rc-slider-handle')); + expect(onChangeComplete).toHaveBeenCalledWith([0, 50]); + }); + it('controlled', () => { const onChange = jest.fn(); const onChangeComplete = jest.fn();