mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-05 09:49:57 +08:00
c3e51506cc
* feat: add Space.Compact * feat: update input style * feat: add CompactItem for context memoize * feat: add demo * feat: update button style * feat: update input style * feat: 提取 getCompactClassNames 公用方法 * feat: update button style * feat: update picker * feat: add block prop for Space.Compact * feat: use Space.Compact for Input#addonBefore/After * feat: update addon * refactor: compact * feat: update * feat: update * feat: migrate styles to compact for new Input/Input.Search * feat: organize input demo * feat: add more button compact demo * feat: resolve select border collapse * feat: fix input addon select style * feat: add input addon demo in Space * feat: add useCompactItemContext hook * feat: update compact-item style * feat: rollback input#addon implements * feat: rollback input#addon and input.search style * feat: select border collapse * feat: add Space.Compact demo * feat: Space.Compact vertical for Button * refactor: useCompactItemContext * feat: update Button vertical demo * feat: rtl for compact mixin * feat: rtl for compact button * feat: input rtl * feat: add docs for Space.Compact * test: add some tests for Space.Compact * test: add tests * feat: select style * feat: handle select focus style * feat: add useCompactItemContext for Picker and Cascader * style: add compact-item style for cascader * feat: support nested Space.Compact * style: Input.Search in Space.Compact * chore: clean * feat: add useCompactItemContext for TreeSelect * fix: lint issues * fix: style lint * docs: update demos for Space.Compact * docs: update demo * fix: add deps-lint-skip for space * fix: add deps-lint-skip for space * fix: handle edge case for useCompactItemContext * test: add search test case * chore: + bundlesize * style: merge button compact style into one file * style: improve style for nested compact * fix: stylelint * docs: update Space.Compact docs * test: update demo snapshot * test: update input debug test snapshot * docs: update doccs for Space.Compact * test: improve test cases for Compact * docs: clean demos for Compact * refactor: improve Space.Compact * fix: add useCompactItemContext for Input.Search * style: improve compact border-radius implementation * refactor: use context to make nested compact works * fix: input-number focused style * refactor: remove useless style * refactor: improve style for vertical compact * test: update snapshot * test: update snapshot for input * refactor: improve compact-item-border-radius * fix: search group in RTL * style: improve style for button compact * style: use after * fix: stylelint * chore: update snapshot * style: improve button compact * refactor: improve btn-icon-only style in compact
186 lines
5.2 KiB
TypeScript
186 lines
5.2 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 Input from '../../input';
|
|
import Button from '../../button';
|
|
import AutoComplete from '../../auto-complete';
|
|
import Cascader from '../../cascader';
|
|
import DatePicker from '../../date-picker';
|
|
import Select from '../../select';
|
|
import TimePicker from '../../time-picker';
|
|
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('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);
|
|
});
|
|
});
|