mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-18 22:36:31 +08:00
502dac12aa
* docs: fix code * feat: lint * feat: prettier * feat: test * feat: review * feat: format html * feat: format html
379 lines
11 KiB
TypeScript
379 lines
11 KiB
TypeScript
/* eslint-disable no-console */
|
|
import React from 'react';
|
|
|
|
import Space from '..';
|
|
import mountTest from '../../../tests/shared/mountTest';
|
|
import rtlTest from '../../../tests/shared/rtlTest';
|
|
import { render } from '../../../tests/utils';
|
|
import AutoComplete from '../../auto-complete';
|
|
import Button from '../../button';
|
|
import Cascader from '../../cascader';
|
|
import ConfigProvider from '../../config-provider';
|
|
import DatePicker from '../../date-picker';
|
|
import Drawer from '../../drawer';
|
|
import Dropdown from '../../dropdown';
|
|
import Input from '../../input';
|
|
import InputNumber from '../../input-number';
|
|
import Modal from '../../modal';
|
|
import Select from '../../select';
|
|
import TimePicker from '../../time-picker';
|
|
import Tooltip from '../../tooltip';
|
|
import TreeSelect from '../../tree-select';
|
|
|
|
describe('Space.Compact', () => {
|
|
mountTest(Space.Compact);
|
|
mountTest(() => (
|
|
<Space.Compact>
|
|
<Button type="primary">Submit</Button>
|
|
</Space.Compact>
|
|
));
|
|
|
|
rtlTest(Space.Compact);
|
|
rtlTest(() => (
|
|
<Space.Compact>
|
|
<Button type="primary">Submit</Button>
|
|
</Space.Compact>
|
|
));
|
|
|
|
it('should render width empty children', () => {
|
|
const { container } = render(<Space.Compact />);
|
|
|
|
expect(container.children.length).toBe(0);
|
|
});
|
|
|
|
it('block className', () => {
|
|
const { container } = render(
|
|
<Space.Compact block>
|
|
<Input defaultValue="https://ant.design" />
|
|
<Button type="primary">Submit</Button>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
container.querySelector('.ant-space-compact')?.classList.contains('ant-space-compact-block'),
|
|
).toBe(true);
|
|
});
|
|
|
|
it('compact-item className', () => {
|
|
const { container } = render(
|
|
<Space.Compact>
|
|
<Input defaultValue="https://ant.design" />
|
|
<Input.Search />
|
|
<Button type="primary">Submit</Button>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
container.querySelector('.ant-input')?.classList.contains('ant-input-compact-item'),
|
|
).toBe(true);
|
|
expect(
|
|
container.querySelector('.ant-input-search')?.classList.contains('ant-input-compact-item'),
|
|
).toBe(true);
|
|
expect(
|
|
container.querySelector('.ant-input')?.classList.contains('ant-input-compact-first-item'),
|
|
).toBe(true);
|
|
expect(
|
|
container
|
|
.querySelector('.ant-btn-compact-item')
|
|
?.classList.contains('ant-btn-compact-last-item'),
|
|
).toBe(true);
|
|
});
|
|
|
|
[
|
|
{
|
|
name: 'Button',
|
|
component: Button,
|
|
targetCls: 'ant-btn',
|
|
expectClsPrefix: 'ant-btn',
|
|
},
|
|
{
|
|
name: 'AutoComplete',
|
|
component: AutoComplete,
|
|
targetCls: 'ant-select',
|
|
expectClsPrefix: 'ant-select',
|
|
},
|
|
{
|
|
name: 'Cascader',
|
|
component: Cascader,
|
|
targetCls: 'ant-cascader',
|
|
expectClsPrefix: 'ant-select',
|
|
},
|
|
{
|
|
name: 'DatePicker',
|
|
component: DatePicker,
|
|
targetCls: 'ant-picker',
|
|
expectClsPrefix: 'ant-picker',
|
|
},
|
|
{
|
|
name: 'Input',
|
|
component: Input,
|
|
targetCls: 'ant-input',
|
|
expectClsPrefix: 'ant-input',
|
|
},
|
|
{
|
|
name: 'Input.Search',
|
|
component: Input.Search,
|
|
targetCls: 'ant-input-search',
|
|
expectClsPrefix: 'ant-input',
|
|
},
|
|
{
|
|
name: 'Select',
|
|
component: Select,
|
|
targetCls: 'ant-select',
|
|
expectClsPrefix: 'ant-select',
|
|
},
|
|
{
|
|
name: 'TimePicker',
|
|
component: TimePicker,
|
|
targetCls: 'ant-picker',
|
|
expectClsPrefix: 'ant-picker',
|
|
},
|
|
{
|
|
name: 'TreeSelect',
|
|
component: TreeSelect,
|
|
targetCls: 'ant-select',
|
|
expectClsPrefix: 'ant-select',
|
|
},
|
|
].forEach(({ component, name, targetCls, expectClsPrefix }) => {
|
|
it(`compact-item for ${name}`, () => {
|
|
const { container } = render(
|
|
<Space.Compact>{React.createElement(component as any)}</Space.Compact>,
|
|
);
|
|
expect(container.querySelectorAll(`.${targetCls}`).length).toBe(1);
|
|
['compact-item', 'compact-first-item', 'compact-last-item'].forEach((suffix) => {
|
|
expect(
|
|
container
|
|
.querySelector(`.${targetCls}`)
|
|
?.classList.contains([expectClsPrefix, suffix].join('-')),
|
|
).toBe(true);
|
|
});
|
|
});
|
|
});
|
|
|
|
it('size', () => {
|
|
const { container } = render(
|
|
<Space.Compact size="small">
|
|
<Input defaultValue="https://ant.design" />
|
|
<Button type="primary">Submit</Button>
|
|
</Space.Compact>,
|
|
);
|
|
expect(container.querySelector('.ant-input')?.classList.contains('ant-input-sm')).toBe(true);
|
|
expect(container.querySelector('.ant-btn')?.classList.contains('ant-btn-sm')).toBe(true);
|
|
});
|
|
it('component size has a higher priority than Compact', () => {
|
|
const { container } = render(
|
|
<Space.Compact size="middle">
|
|
<Input size="small" />
|
|
<Select size="small" />
|
|
<Button size="small">Submit</Button>
|
|
<InputNumber size="small" />
|
|
<DatePicker size="small" />
|
|
<DatePicker.RangePicker size="small" />
|
|
<Cascader size="small" />
|
|
<TreeSelect size="small" />
|
|
<Input.Search size="small" />
|
|
</Space.Compact>,
|
|
);
|
|
expect(container.querySelector('.ant-input')?.classList.contains('ant-input-sm')).toBe(true);
|
|
expect(container.querySelector('.ant-select')?.classList.contains('ant-select-sm')).toBe(true);
|
|
expect(container.querySelector('.ant-btn')?.classList.contains('ant-btn-sm')).toBe(true);
|
|
expect(
|
|
container.querySelector('.ant-input-number')?.classList.contains('ant-input-number-sm'),
|
|
).toBe(true);
|
|
expect(container.querySelector('.ant-picker')?.classList.contains('ant-picker-small')).toBe(
|
|
true,
|
|
);
|
|
expect(
|
|
container.querySelector('.ant-picker-range')?.classList.contains('ant-picker-small'),
|
|
).toBe(true);
|
|
expect(container.querySelector('.ant-cascader')?.classList.contains('ant-select-sm')).toBe(
|
|
true,
|
|
);
|
|
expect(container.querySelector('.ant-tree-select')?.classList.contains('ant-select-sm')).toBe(
|
|
true,
|
|
);
|
|
expect(
|
|
container.querySelector('.ant-input-search')?.classList.contains('ant-input-search-small'),
|
|
).toBe(true);
|
|
});
|
|
|
|
it('direction=vertical', () => {
|
|
const { container } = render(
|
|
<Space.Compact size="small" direction="vertical">
|
|
<Button type="primary">Button 1</Button>
|
|
<Button type="primary">Button 2</Button>
|
|
<Button type="primary">Button 3</Button>
|
|
<Button type="primary">Button 4</Button>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
container
|
|
.querySelector('.ant-space-compact')
|
|
?.classList.contains('ant-space-compact-vertical'),
|
|
).toBe(true);
|
|
expect(
|
|
container.querySelector('.ant-btn')?.classList.contains('ant-btn-compact-vertical-item'),
|
|
).toBe(true);
|
|
|
|
expect(
|
|
container
|
|
.querySelectorAll('.ant-btn')[0]
|
|
?.classList.contains('ant-btn-compact-vertical-first-item'),
|
|
).toBe(true);
|
|
|
|
expect(
|
|
container
|
|
.querySelectorAll('.ant-btn')[3]
|
|
?.classList.contains('ant-btn-compact-vertical-last-item'),
|
|
).toBe(true);
|
|
});
|
|
it('context for Modal', () => {
|
|
render(
|
|
<Space.Compact size="small">
|
|
<Modal title="Basic Modal" open>
|
|
<Button>normal button A</Button>
|
|
<Input />
|
|
</Modal>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
document.body
|
|
.querySelectorAll('.ant-modal')[0]
|
|
.querySelector('.ant-btn')
|
|
?.classList.contains('ant-btn-compact-item'),
|
|
).toBe(false);
|
|
expect(
|
|
document.body
|
|
.querySelectorAll('.ant-modal')[0]
|
|
.querySelector('.ant-input')
|
|
?.classList.contains('ant-input-compact-item'),
|
|
).toBe(false);
|
|
});
|
|
it('context for Dropdown', () => {
|
|
render(
|
|
<Space.Compact size="small">
|
|
<Dropdown.Button
|
|
open
|
|
menu={{
|
|
items: [
|
|
{
|
|
key: '1',
|
|
label: <Button>menu button</Button>,
|
|
},
|
|
],
|
|
}}
|
|
>
|
|
debug Dropdown.Button context
|
|
</Dropdown.Button>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
document.body
|
|
.querySelector('.ant-dropdown')
|
|
?.querySelector('.ant-btn')
|
|
?.classList.contains('ant-btn-compact-item'),
|
|
).toBe(false);
|
|
});
|
|
it('context for Drawer', () => {
|
|
render(
|
|
<Space.Compact size="small">
|
|
<Drawer title="Basic Drawer" open>
|
|
<Button>normal button A</Button>
|
|
</Drawer>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
document.body
|
|
.querySelector('.ant-drawer')
|
|
?.querySelector('.ant-btn')
|
|
?.classList.contains('ant-btn-compact-item'),
|
|
).toBe(false);
|
|
});
|
|
it('context for Tooltip', () => {
|
|
render(
|
|
<Space.Compact>
|
|
<Input placeholder="Debug Popover context" />
|
|
<Tooltip
|
|
open
|
|
overlay={
|
|
<>
|
|
<Input placeholder="Left Border" />
|
|
<DatePicker />
|
|
</>
|
|
}
|
|
trigger={['click']}
|
|
placement="bottom"
|
|
>
|
|
<Button>Settings</Button>
|
|
</Tooltip>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
document.body
|
|
.querySelector('.ant-tooltip')
|
|
?.querySelector('.ant-input')
|
|
?.classList.contains('ant-input-compact-item'),
|
|
).toBe(false);
|
|
expect(
|
|
document.body
|
|
.querySelector('.ant-tooltip')
|
|
?.querySelector('.ant-picker')
|
|
?.classList.contains('ant-picker-compact-item'),
|
|
).toBe(false);
|
|
});
|
|
|
|
it('Tooltip content supports function', () => {
|
|
render(
|
|
<Space.Compact>
|
|
<Input placeholder="Debug Popover context" />
|
|
<Tooltip
|
|
open
|
|
overlay={() => (
|
|
<>
|
|
<Input placeholder="Left Border" />
|
|
<DatePicker />
|
|
</>
|
|
)}
|
|
>
|
|
<span>Tooltip will show on mouse enter.</span>
|
|
</Tooltip>
|
|
</Space.Compact>,
|
|
);
|
|
expect(
|
|
document.body
|
|
.querySelector('.ant-tooltip')
|
|
?.querySelector('.ant-input')
|
|
?.classList.contains('ant-input-compact-item'),
|
|
).toBe(false);
|
|
expect(
|
|
document.body
|
|
.querySelector('.ant-tooltip')
|
|
?.querySelector('.ant-picker')
|
|
?.classList.contains('ant-picker-compact-item'),
|
|
).toBe(false);
|
|
});
|
|
|
|
// https://github.com/ant-design/ant-design/issues/41876
|
|
it('Space.Compact should inherit the size from ConfigProvider if the componentSize is set', () => {
|
|
const { container } = render(
|
|
<ConfigProvider componentSize="large">
|
|
<Space.Compact>
|
|
<Select placeholder="Select" />
|
|
</Space.Compact>
|
|
</ConfigProvider>,
|
|
);
|
|
|
|
expect(container.querySelectorAll('.ant-select-lg')).toHaveLength(1);
|
|
});
|
|
|
|
it('The size property of Space.Compact should have an higher priority over the componentSize property of ConfigProvider', () => {
|
|
const { container } = render(
|
|
<ConfigProvider componentSize="large">
|
|
<Space.Compact size="small">
|
|
<Select placeholder="Select" />
|
|
</Space.Compact>
|
|
</ConfigProvider>,
|
|
);
|
|
|
|
expect(container.querySelectorAll('.ant-select-sm')).toHaveLength(1);
|
|
});
|
|
});
|