import React from 'react'; import { closePicker, openPicker, selectCell } from '../../date-picker/__tests__/utils'; import ConfigProvider from '..'; import DatePicker from '../../date-picker'; import type { Locale } from '../../locale'; import LocaleProvider from '../../locale'; import enUS from '../../locale/en_US'; import zhCN from '../../locale/zh_CN'; import Modal from '../../modal'; import Pagination from '../../pagination'; import TimePicker from '../../time-picker'; import { act, render, fireEvent } from '../../../tests/utils'; describe('ConfigProvider.Locale', () => { function $$(selector: string): NodeListOf { return document.body.querySelectorAll(selector); } it('not throw', () => { render( , ); }); // https://github.com/ant-design/ant-design/issues/18731 it('should not reset locale for Modal', () => { class App extends React.Component { state = { showButton: false }; componentDidMount() { this.setState({ showButton: true }); } // eslint-disable-next-line class-methods-use-this openConfirm = () => { jest.useFakeTimers(); Modal.confirm({ title: 'title', content: 'Some descriptions' }); act(() => { jest.runAllTimers(); }); jest.useRealTimers(); }; render() { return ( {this.state.showButton ? ( ) : null} ); } } const wrapper = render(); fireEvent.click(wrapper.container.querySelector('button')!); expect($$('.ant-btn-primary')[0].textContent).toBe('OK'); }); // https://github.com/ant-design/ant-design/issues/31592 it('should not reset the component state when switching locale', () => { const wrapper = render( , ); const datepicke = wrapper.container.querySelector('.ant-picker-input input'); expect(datepicke?.value).toBe(''); expect(datepicke?.placeholder).toBe('请选择日期'); expect(wrapper.container.querySelector('.ant-pagination-item-1')?.className).toContain( 'ant-pagination-item-active', ); openPicker(wrapper); selectCell(wrapper, 10); closePicker(wrapper); expect( wrapper.container.querySelector('.ant-picker-input input')?.value, ).not.toBe(''); wrapper.rerender( , ); fireEvent.click(wrapper.container.querySelector('.ant-pagination-item-3')!); const datepicker = wrapper.container.querySelector('.ant-picker-input input'); expect(datepicker?.placeholder).not.toBe('请选择日期'); expect(datepicker?.value).not.toBe(''); expect(datepicker?.value).toContain('-10'); expect(wrapper.container.querySelector('.ant-pagination-item-3')?.className).toContain( 'ant-pagination-item-active', ); }); describe('support legacy LocaleProvider', () => { function testLocale(wrapper: ReturnType): void { expect(wrapper.container.querySelector('input')?.placeholder).toBe( zhCN.TimePicker?.placeholder, ); } it('LocaleProvider', () => { testLocale( render( , ), ); }); it('LocaleProvider > ConfigProvider', () => { testLocale( render( , ), ); }); it('ConfigProvider > ConfigProvider', () => { testLocale( render( , ), ); }); }); });