mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-25 03:29:59 +08:00
parent
78fe0a686f
commit
65d1f721d3
@ -4,7 +4,7 @@ import { renderToJson } from 'enzyme-to-json';
|
|||||||
import Table from '..';
|
import Table from '..';
|
||||||
|
|
||||||
describe('Table.filter', () => {
|
describe('Table.filter', () => {
|
||||||
const filterFn = (value, record) => record.name === 'Lucy';
|
const filterFn = (value, record) => record.name.indexOf(value) !== -1;
|
||||||
const column = {
|
const column = {
|
||||||
title: 'Name',
|
title: 'Name',
|
||||||
dataIndex: 'name',
|
dataIndex: 'name',
|
||||||
@ -41,6 +41,10 @@ describe('Table.filter', () => {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function renderedNames(wrapper) {
|
||||||
|
return wrapper.find('TableRow').map(row => row.props().record.name);
|
||||||
|
}
|
||||||
|
|
||||||
it('renders filter correctly', () => {
|
it('renders filter correctly', () => {
|
||||||
const wrapper = render(createTable());
|
const wrapper = render(createTable());
|
||||||
|
|
||||||
@ -116,7 +120,7 @@ describe('Table.filter', () => {
|
|||||||
const wrapper = mount(createTable({
|
const wrapper = mount(createTable({
|
||||||
columns: [{
|
columns: [{
|
||||||
...column,
|
...column,
|
||||||
filteredValue: ['girl'],
|
filteredValue: ['Lucy'],
|
||||||
}],
|
}],
|
||||||
}));
|
}));
|
||||||
|
|
||||||
@ -154,4 +158,40 @@ describe('Table.filter', () => {
|
|||||||
|
|
||||||
expect(handleChange).toBeCalledWith({}, { name: ['boy'] }, {});
|
expect(handleChange).toBeCalledWith({}, { name: ['boy'] }, {});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('three levels menu', () => {
|
||||||
|
const filters = [
|
||||||
|
{ text: 'Upper', value: 'Upper' },
|
||||||
|
{ text: 'Lower', value: 'Lower' },
|
||||||
|
{
|
||||||
|
text: 'Level2',
|
||||||
|
value: 'Level2',
|
||||||
|
children: [
|
||||||
|
{ text: 'Large', value: 'Large' },
|
||||||
|
{ text: 'Small', value: 'Small' },
|
||||||
|
{
|
||||||
|
text: 'Level3',
|
||||||
|
value: 'Level3',
|
||||||
|
children: [
|
||||||
|
{ text: 'Black', value: 'Black' },
|
||||||
|
{ text: 'White', value: 'White' },
|
||||||
|
{ text: 'Jack', value: 'Jack' },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
];
|
||||||
|
const wrapper = mount(createTable({
|
||||||
|
columns: [{
|
||||||
|
...column,
|
||||||
|
filters,
|
||||||
|
}],
|
||||||
|
}));
|
||||||
|
const dropdownWrapper = mount(wrapper.find('Trigger').node.getComponent());
|
||||||
|
dropdownWrapper.find('.ant-dropdown-menu-submenu-title').at(0).simulate('mouseEnter');
|
||||||
|
dropdownWrapper.find('.ant-dropdown-menu-submenu-title').at(1).simulate('mouseEnter');
|
||||||
|
dropdownWrapper.find('MenuItem').last().simulate('click');
|
||||||
|
dropdownWrapper.find('.confirm').simulate('click');
|
||||||
|
expect(renderedNames(wrapper)).toEqual(['Jack']);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
@ -122,7 +122,7 @@ export default class FilterMenu extends React.Component<FilterMenuProps, any> {
|
|||||||
const subMenuCls = containSelected ? `${this.props.dropdownPrefixCls}-submenu-contain-selected` : '';
|
const subMenuCls = containSelected ? `${this.props.dropdownPrefixCls}-submenu-contain-selected` : '';
|
||||||
return (
|
return (
|
||||||
<SubMenu title={item.text} className={subMenuCls} key={item.value.toString()}>
|
<SubMenu title={item.text} className={subMenuCls} key={item.value.toString()}>
|
||||||
{item.children.map(child => this.renderMenuItem(child))}
|
{this.renderMenus(item.children)}
|
||||||
</SubMenu>
|
</SubMenu>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user