mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-05 09:30:32 +08:00
21194da96a
* feat: Slider support editable * test: update snapshot * test: update snapshot * docs: update docs * chore: fix lint * test: update snapshot * test: coverage
96 lines
2.9 KiB
TypeScript
96 lines
2.9 KiB
TypeScript
import React from 'react';
|
|
|
|
import Slider from '..';
|
|
import { fireEvent, render, waitFakeTimer } from '../../../tests/utils';
|
|
import type { TooltipProps, TooltipRef } from '../../tooltip';
|
|
|
|
function tooltipProps(): TooltipProps {
|
|
return (global as any).tooltipProps;
|
|
}
|
|
|
|
jest.mock('../../tooltip', () => {
|
|
const ReactReal: typeof React = jest.requireActual('react');
|
|
const Tooltip = jest.requireActual('../../tooltip');
|
|
const TooltipComponent = Tooltip.default;
|
|
return ReactReal.forwardRef<TooltipRef, TooltipProps>((props, ref) => {
|
|
(global as any).tooltipProps = props;
|
|
return <TooltipComponent {...props} ref={ref} />;
|
|
});
|
|
});
|
|
|
|
describe('Slider.Tooltip', () => {
|
|
beforeEach(() => {
|
|
jest.useFakeTimers();
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.clearAllTimers();
|
|
jest.useRealTimers();
|
|
});
|
|
|
|
it('Correct show the tooltip', async () => {
|
|
const { container } = render(<Slider defaultValue={30} />);
|
|
|
|
const handleEle = container.querySelector('.ant-slider-handle')!;
|
|
|
|
// Enter
|
|
fireEvent.mouseEnter(handleEle);
|
|
await waitFakeTimer();
|
|
expect(tooltipProps().open).toBeTruthy();
|
|
|
|
// Down
|
|
fireEvent.mouseDown(handleEle);
|
|
await waitFakeTimer();
|
|
expect(tooltipProps().open).toBeTruthy();
|
|
|
|
// Move(Leave)
|
|
fireEvent.mouseLeave(handleEle);
|
|
await waitFakeTimer();
|
|
expect(tooltipProps().open).toBeTruthy();
|
|
|
|
// Up
|
|
fireEvent.mouseUp(handleEle);
|
|
await waitFakeTimer();
|
|
expect(tooltipProps().open).toBeFalsy();
|
|
});
|
|
|
|
it('range show the tooltip', async () => {
|
|
const { container } = render(<Slider range defaultValue={[0, 100]} />);
|
|
|
|
const handleEle = container.querySelector('.ant-slider-handle')!;
|
|
|
|
// Enter
|
|
fireEvent.mouseEnter(handleEle);
|
|
await waitFakeTimer();
|
|
expect(tooltipProps().open).toBeTruthy();
|
|
});
|
|
|
|
it('tooltip should not display when formatter is null or open is false', async () => {
|
|
// https://github.com/ant-design/ant-design/issues/48668
|
|
const { container: container1 } = render(
|
|
<Slider defaultValue={30} tooltip={{ formatter: null }} />,
|
|
);
|
|
// https://github.com/ant-design/ant-design/issues/48707
|
|
const { container: container2 } = render(
|
|
<Slider defaultValue={30} tooltip={{ open: false }} />,
|
|
);
|
|
|
|
const handler1 = container1.querySelector('.ant-slider-handle')!;
|
|
const handler2 = container2.querySelector('.ant-slider-handle')!;
|
|
|
|
// Enter
|
|
fireEvent.mouseEnter(handler1);
|
|
fireEvent.mouseEnter(handler2);
|
|
await waitFakeTimer();
|
|
expect(container1.querySelector('.ant-tooltip-open')).toBeFalsy();
|
|
expect(container2.querySelector('.ant-tooltip-open')).toBeFalsy();
|
|
|
|
// Down
|
|
fireEvent.focus(handler1);
|
|
fireEvent.focus(handler2);
|
|
await waitFakeTimer();
|
|
expect(container1.querySelector('.ant-tooltip-open')).toBeFalsy();
|
|
expect(container2.querySelector('.ant-tooltip-open')).toBeFalsy();
|
|
});
|
|
});
|