2017-01-14 15:23:02 +08:00
|
|
|
import React from 'react';
|
|
|
|
import { mount } from 'enzyme';
|
|
|
|
import Tooltip from '..';
|
2017-02-16 14:03:05 +08:00
|
|
|
import Button from '../../button';
|
2017-01-14 15:23:02 +08:00
|
|
|
|
|
|
|
describe('Tooltip', () => {
|
|
|
|
it('check `onVisibleChange` arguments', () => {
|
|
|
|
const onVisibleChange = jest.fn();
|
|
|
|
|
|
|
|
const wrapper = mount(
|
|
|
|
<Tooltip
|
|
|
|
title=""
|
|
|
|
mouseEnterDelay={0}
|
|
|
|
mouseLeaveDelay={0}
|
|
|
|
onVisibleChange={onVisibleChange}
|
|
|
|
>
|
|
|
|
<div>Hello world!</div>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
|
|
|
|
// `title` is empty.
|
|
|
|
const div = wrapper.find('div').at(0);
|
|
|
|
div.simulate('mouseenter');
|
|
|
|
expect(onVisibleChange).not.toHaveBeenCalled();
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(false);
|
2017-01-14 15:23:02 +08:00
|
|
|
|
|
|
|
div.simulate('mouseleave');
|
|
|
|
expect(onVisibleChange).not.toHaveBeenCalled();
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(false);
|
2017-01-14 15:23:02 +08:00
|
|
|
|
|
|
|
// update `title` value.
|
|
|
|
wrapper.setProps({ title: 'Have a nice day!' });
|
|
|
|
wrapper.simulate('mouseenter');
|
2017-01-15 00:27:02 +08:00
|
|
|
expect(onVisibleChange).toHaveBeenLastCalledWith(true);
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(true);
|
2017-01-14 15:23:02 +08:00
|
|
|
|
|
|
|
wrapper.simulate('mouseleave');
|
2017-01-15 00:27:02 +08:00
|
|
|
expect(onVisibleChange).toHaveBeenLastCalledWith(false);
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(false);
|
2017-01-14 15:23:02 +08:00
|
|
|
|
|
|
|
// add `visible` props.
|
|
|
|
wrapper.setProps({ visible: false });
|
|
|
|
wrapper.simulate('mouseenter');
|
2017-01-15 00:27:02 +08:00
|
|
|
expect(onVisibleChange).toHaveBeenLastCalledWith(true);
|
|
|
|
const lastCount = onVisibleChange.mock.calls.length;
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(false);
|
2017-01-14 15:23:02 +08:00
|
|
|
|
2017-01-15 00:27:02 +08:00
|
|
|
// always trigger onVisibleChange
|
2017-01-14 15:23:02 +08:00
|
|
|
wrapper.simulate('mouseleave');
|
2017-01-15 00:27:02 +08:00
|
|
|
expect(onVisibleChange.mock.calls.length).toBe(lastCount); // no change with lastCount
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(false);
|
2017-01-14 15:23:02 +08:00
|
|
|
});
|
2017-02-16 14:03:05 +08:00
|
|
|
|
|
|
|
it('should hide when mouse leave native disabled button', () => {
|
|
|
|
const onVisibleChange = jest.fn();
|
|
|
|
const wrapper = mount(
|
|
|
|
<Tooltip
|
|
|
|
title="xxxxx"
|
|
|
|
mouseEnterDelay={0}
|
|
|
|
mouseLeaveDelay={0}
|
|
|
|
onVisibleChange={onVisibleChange}
|
|
|
|
>
|
|
|
|
<button disabled>Hello world!</button>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(wrapper.find('span')).toHaveLength(1);
|
|
|
|
const button = wrapper.find('span').at(0);
|
|
|
|
button.simulate('mouseenter');
|
|
|
|
expect(onVisibleChange).toBeCalledWith(true);
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(true);
|
2017-02-16 14:03:05 +08:00
|
|
|
|
|
|
|
button.simulate('mouseleave');
|
|
|
|
expect(onVisibleChange).toBeCalledWith(false);
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(false);
|
2017-02-16 14:03:05 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should hide when mouse leave antd disabled Button', () => {
|
|
|
|
const onVisibleChange = jest.fn();
|
|
|
|
const wrapper = mount(
|
|
|
|
<Tooltip
|
|
|
|
title="xxxxx"
|
|
|
|
mouseEnterDelay={0}
|
|
|
|
mouseLeaveDelay={0}
|
|
|
|
onVisibleChange={onVisibleChange}
|
|
|
|
>
|
|
|
|
<Button disabled>Hello world!</Button>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(wrapper.getDOMNode().tagName).toBe('SPAN');
|
|
|
|
const button = wrapper.find('span').at(0);
|
|
|
|
button.simulate('mouseenter');
|
|
|
|
expect(onVisibleChange).toBeCalledWith(true);
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(true);
|
2017-02-16 14:03:05 +08:00
|
|
|
|
|
|
|
button.simulate('mouseleave');
|
|
|
|
expect(onVisibleChange).toBeCalledWith(false);
|
2017-09-08 09:45:34 +08:00
|
|
|
expect(wrapper.instance().tooltip.props.visible).toBe(false);
|
2017-02-16 14:03:05 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should render disabled Button style properly', () => {
|
|
|
|
const wrapper1 = mount(
|
|
|
|
<Tooltip title="xxxxx">
|
|
|
|
<Button disabled>Hello world!</Button>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
const wrapper2 = mount(
|
|
|
|
<Tooltip title="xxxxx">
|
|
|
|
<Button disabled style={{ display: 'block' }}>Hello world!</Button>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
expect(wrapper1.getDOMNode().style.display).toBe('inline-block');
|
|
|
|
expect(wrapper2.getDOMNode().style.display).toBe('block');
|
|
|
|
});
|
2017-03-14 19:04:18 +08:00
|
|
|
|
|
|
|
it('should not wrap span when trigger is not hover', () => {
|
|
|
|
const wrapper = mount(
|
|
|
|
<Tooltip
|
|
|
|
title="xxxxx"
|
|
|
|
trigger="click"
|
|
|
|
mouseEnterDelay={0}
|
|
|
|
mouseLeaveDelay={0}
|
|
|
|
>
|
|
|
|
<button disabled>Hello world!</button>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(wrapper.find('span')).toHaveLength(0);
|
|
|
|
});
|
2017-07-16 16:00:23 +08:00
|
|
|
|
|
|
|
it('should works for arrowPointAtCenter', () => {
|
|
|
|
const arrowWidth = 5;
|
|
|
|
const horizontalArrowShift = 16;
|
|
|
|
const triggerWidth = 200;
|
|
|
|
|
|
|
|
const wrapper = mount(
|
|
|
|
<Tooltip
|
|
|
|
title="xxxxx"
|
|
|
|
trigger="click"
|
|
|
|
mouseEnterDelay={0}
|
|
|
|
mouseLeaveDelay={0}
|
|
|
|
placement="bottomLeft"
|
|
|
|
>
|
|
|
|
<button style={{ width: triggerWidth }}>
|
|
|
|
Hello world!
|
|
|
|
</button>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
wrapper.find('button').at(0).simulate('click');
|
|
|
|
const popupLeftDefault = parseInt(wrapper.node.getPopupDomNode().style.left, 10);
|
|
|
|
|
|
|
|
const wrapper2 = mount(
|
|
|
|
<Tooltip
|
|
|
|
title="xxxxx"
|
|
|
|
trigger="click"
|
|
|
|
mouseEnterDelay={0}
|
|
|
|
mouseLeaveDelay={0}
|
|
|
|
placement="bottomLeft"
|
|
|
|
arrowPointAtCenter
|
|
|
|
>
|
|
|
|
<button style={{ width: triggerWidth }}>
|
|
|
|
Hello world!
|
|
|
|
</button>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
wrapper2.find('button').at(0).simulate('click');
|
|
|
|
const popupLeftArrowPointAtCenter = parseInt(wrapper2.node.getPopupDomNode().style.left, 10);
|
|
|
|
expect(popupLeftArrowPointAtCenter - popupLeftDefault).toBe((triggerWidth / 2) - horizontalArrowShift - arrowWidth);
|
|
|
|
});
|
2017-01-14 15:23:02 +08:00
|
|
|
});
|