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) => (
{items?.map((item, idx) => {
const key = `panel-${idx}`;
return ;
})}
);
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(
,
);
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(
,
);
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(
,
);
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]);
});
});