/* 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(() => ( )); rtlTest(Space.Compact); rtlTest(() => ( )); it('should render width empty children', () => { const { container } = render(); expect(container.children.length).toBe(0); }); it('block className', () => { const { container } = render( , ); expect( container.querySelector('.ant-space-compact')?.classList.contains('ant-space-compact-block'), ).toBe(true); }); it('compact-item className', () => { const { container } = render( , ); 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( {React.createElement(component as any)}, ); 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( , ); 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( , ); 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); }); });