mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-23 18:04:12 +08:00
209 lines
5.3 KiB
TypeScript
209 lines
5.3 KiB
TypeScript
|
import React from 'react';
|
||
|
import { createEvent, fireEvent, render } from '@testing-library/react';
|
||
|
import { Splitter } from 'antd';
|
||
|
import { spyElementPrototypes } from 'rc-util/lib/test/domHook';
|
||
|
import { resetWarned } from 'rc-util/lib/warning';
|
||
|
|
||
|
import { triggerResize, waitFakeTimer } from '../../../tests/utils';
|
||
|
import { PanelProps, SplitterProps } from '../interface';
|
||
|
|
||
|
const SplitterDemo = ({ items = [{}, {}], ...props }: { items?: PanelProps[] } & SplitterProps) => (
|
||
|
<Splitter {...props}>
|
||
|
{items?.map((item, idx) => {
|
||
|
const key = `panel-${idx}`;
|
||
|
return <Splitter.Panel key={key} {...item} />;
|
||
|
})}
|
||
|
</Splitter>
|
||
|
);
|
||
|
|
||
|
const resizeSplitter = async () => {
|
||
|
triggerResize(document.body.querySelector('.ant-splitter')!);
|
||
|
await waitFakeTimer();
|
||
|
};
|
||
|
|
||
|
describe('Splitter lazy', () => {
|
||
|
const errSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
|
||
|
|
||
|
let containerSize = 100;
|
||
|
|
||
|
beforeAll(() => {
|
||
|
spyElementPrototypes(HTMLElement, {
|
||
|
offsetWidth: {
|
||
|
get: () => containerSize,
|
||
|
},
|
||
|
offsetHeight: {
|
||
|
get: () => containerSize,
|
||
|
},
|
||
|
});
|
||
|
});
|
||
|
|
||
|
beforeEach(() => {
|
||
|
containerSize = 100;
|
||
|
errSpy.mockReset();
|
||
|
resetWarned();
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
jest.clearAllTimers();
|
||
|
jest.useRealTimers();
|
||
|
});
|
||
|
|
||
|
const mockDrag = (draggerEle: HTMLElement, onResize: jest.Mock, offset: number) => {
|
||
|
// Down
|
||
|
const downEvent = createEvent.mouseDown(draggerEle);
|
||
|
(downEvent as any).pageX = 0;
|
||
|
(downEvent as any).pageY = 0;
|
||
|
|
||
|
fireEvent(draggerEle, downEvent);
|
||
|
|
||
|
// Move
|
||
|
const moveEvent = createEvent.mouseMove(window);
|
||
|
(moveEvent as any).pageX = offset;
|
||
|
(moveEvent as any).pageY = offset;
|
||
|
fireEvent(window, moveEvent);
|
||
|
|
||
|
expect(onResize).not.toHaveBeenCalled();
|
||
|
|
||
|
// Up
|
||
|
fireEvent.mouseUp(window);
|
||
|
};
|
||
|
|
||
|
const mockTouchDrag = (draggerEle: HTMLElement, onResize: jest.Mock, offset: number) => {
|
||
|
const touchStart = createEvent.touchStart(draggerEle, {
|
||
|
touches: [{ pageX: 0, pageY: 0 }],
|
||
|
});
|
||
|
fireEvent(draggerEle, touchStart);
|
||
|
|
||
|
// Touch Move
|
||
|
const touchMove = createEvent.touchMove(window, {
|
||
|
touches: [{ pageX: offset, pageY: offset }],
|
||
|
});
|
||
|
fireEvent(window, touchMove);
|
||
|
|
||
|
// onResize should not be called during drag
|
||
|
expect(onResize).not.toHaveBeenCalled();
|
||
|
|
||
|
// Touch End
|
||
|
fireEvent.touchEnd(window);
|
||
|
};
|
||
|
|
||
|
it('should only update after mouse up when lazy is true', async () => {
|
||
|
const onResize = jest.fn();
|
||
|
const onResizeEnd = jest.fn();
|
||
|
|
||
|
const { container } = render(
|
||
|
<SplitterDemo
|
||
|
items={[
|
||
|
{
|
||
|
defaultSize: '50%',
|
||
|
min: '30%',
|
||
|
max: '70%',
|
||
|
},
|
||
|
{
|
||
|
defaultSize: '50%',
|
||
|
min: '30%',
|
||
|
max: '70%',
|
||
|
},
|
||
|
]}
|
||
|
onResize={onResize}
|
||
|
onResizeEnd={onResizeEnd}
|
||
|
lazy
|
||
|
/>,
|
||
|
);
|
||
|
|
||
|
await resizeSplitter();
|
||
|
|
||
|
// Right
|
||
|
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([70, 30]);
|
||
|
|
||
|
// Left
|
||
|
onResize.mockReset();
|
||
|
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([30, 70]);
|
||
|
});
|
||
|
|
||
|
it('should work with touch events when lazy', async () => {
|
||
|
const onResize = jest.fn();
|
||
|
const onResizeEnd = jest.fn();
|
||
|
|
||
|
const { container } = render(
|
||
|
<SplitterDemo
|
||
|
items={[
|
||
|
{
|
||
|
defaultSize: '50%',
|
||
|
min: '20%',
|
||
|
max: '70%',
|
||
|
},
|
||
|
{
|
||
|
defaultSize: '50%',
|
||
|
min: '20%',
|
||
|
max: '70%',
|
||
|
},
|
||
|
]}
|
||
|
onResize={onResize}
|
||
|
onResizeEnd={onResizeEnd}
|
||
|
lazy
|
||
|
/>,
|
||
|
);
|
||
|
|
||
|
await resizeSplitter();
|
||
|
|
||
|
// Right
|
||
|
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([70, 30]);
|
||
|
|
||
|
// Left
|
||
|
onResize.mockReset();
|
||
|
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([30, 70]);
|
||
|
});
|
||
|
|
||
|
it('should work with vertical splitter', async () => {
|
||
|
const onResize = jest.fn();
|
||
|
const onResizeEnd = jest.fn();
|
||
|
|
||
|
const { container } = render(
|
||
|
<SplitterDemo
|
||
|
items={[
|
||
|
{
|
||
|
defaultSize: '50%',
|
||
|
min: '30%',
|
||
|
max: '70%',
|
||
|
},
|
||
|
{
|
||
|
defaultSize: '50%',
|
||
|
min: '30%',
|
||
|
max: '70%',
|
||
|
},
|
||
|
]}
|
||
|
onResize={onResize}
|
||
|
onResizeEnd={onResizeEnd}
|
||
|
layout="vertical"
|
||
|
lazy
|
||
|
/>,
|
||
|
);
|
||
|
|
||
|
await resizeSplitter();
|
||
|
|
||
|
// Drag Down
|
||
|
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([70, 30]);
|
||
|
|
||
|
// Drag Up
|
||
|
onResize.mockReset();
|
||
|
mockDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([30, 70]);
|
||
|
|
||
|
// Touch Drag Down
|
||
|
onResize.mockReset();
|
||
|
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, 1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([70, 30]);
|
||
|
|
||
|
// Touch Drag Up
|
||
|
onResize.mockReset();
|
||
|
mockTouchDrag(container.querySelector('.ant-splitter-bar-dragger')!, onResize, -1000);
|
||
|
expect(onResize).toHaveBeenCalledWith([30, 70]);
|
||
|
});
|
||
|
});
|