| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 | import { Modal } from '../../index';// import toJson from 'enzyme-to-json';import { clear } from 'jest-date-mock';import { BASE_CLASS_PREFIX } from '../../../semi-foundation/base/constants';import { cssClasses } from '@douyinfe/semi-foundation/icons/constants';import { IconEyeClosed } from '@douyinfe/semi-icons';const prefixCls = cssClasses.PREFIX;function getModal(modalProps, children) {    let props = modalProps ? modalProps : {};    return (        <Modal            motion={false}            {...props}        >            {children ? children : <p>This is content of basic modal</p>}        </Modal>    );}function mountToBody(component) {    return mount(component, { attachTo: document.getElementById('container') });}describe('modal', () => {    beforeEach(() => {        // Avoid `attachTo: document.body` Warning        const div = document.createElement('div');        div.setAttribute('id', 'container');        document.body.appendChild(div);        clear();    });    afterEach(() => {        document.body.innerHTML = '';    });    it('className / style / maskStyle / bodyStyle / zIndex', () => {        let component = getModal({            className: 'test',            style: { color: 'red' },            visible: true,            maskStyle: { color: 'grey' },            bodyStyle: { color: 'pink' },            zIndex: 500,        });        let modal = mount(component, { attachTo: document.getElementById('container') });        // let modal = mount(component, { attachTo: document.body });        // test className        expect(modal.exists('div.test')).toEqual(true);        // test style        expect(modal.find(`.${BASE_CLASS_PREFIX}-modal`)).toHaveStyle('color', 'red')        // test bodyStyle        expect(modal.find(`.${BASE_CLASS_PREFIX}-modal-body`)).toHaveStyle('color', 'pink');        // test maskStyle        expect(modal.find(`.${BASE_CLASS_PREFIX}-modal-mask`)).toHaveStyle('color', 'grey');        // test zIndex        expect(document.querySelector(`.${BASE_CLASS_PREFIX}-portal`).style.zIndex).toEqual("500");        modal.unmount();    });    it('visible', (done) => {        let component = getModal();        let modal = mount(component, { attachTo: document.getElementById('container') });        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(false);        // set true        modal.setProps({ visible: true });        modal.update(); // 必须调用一次update        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(true);        expect(document.body.style.overflow).toEqual('hidden');        // set false        modal.setProps({ visible: false });        modal.update(); // 必须调用一次update        expect(document.body.style.overflow).not.toEqual('hidden');        setTimeout(() => {            expect(document.querySelector(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(null);            done();        }, 2000);    });    it('render basic content', () => {        let com = getModal({ title: 'SemiTitle', visible: true })        let modal = mount(com, { attachTo: document.getElementById('container') });        // test title        let sheetTitle = document.querySelector(`.${BASE_CLASS_PREFIX}-modal-title`);        expect(sheetTitle.textContent).toEqual('SemiTitle');        // test content        let sheetContent = document.querySelector(`.${BASE_CLASS_PREFIX}-modal-body`);        // the content in getModal could not be overwritten        expect(sheetContent.textContent).toEqual('This is content of basic modal');        modal.unmount();    });    it('footer / header', () => {        let com = getModal({ header: (<p>This is a header</p>), footer: (<p>This is a footer</p>), visible: true })        let modal = mount(com, { attachTo: document.getElementById('container') });        expect(modal.find(`.${BASE_CLASS_PREFIX}-modal-content`).children().at(0).html()).toEqual('<p>This is a header</p>');        expect(modal.find(`.${BASE_CLASS_PREFIX}-modal-footer`).contains(<p>This is a footer</p>)).toEqual(true);        // test null        modal.setProps({ header: null, footer: null });        let content = modal.find(`.${BASE_CLASS_PREFIX}-modal-content`).children();        expect(content.length).toEqual(1);        expect(content.text()).toEqual('This is content of basic modal')        modal.unmount();    });    it('height / width', () => {        let com = getModal({ width: '413px', height: '613px', visible: true })        let modal = mount(com, { attachTo: document.getElementById('container') });        let dom = modal.find(`.${BASE_CLASS_PREFIX}-modal`).getDOMNode();        expect(window.getComputedStyle(dom).width).toEqual('413px')        expect(window.getComputedStyle(dom).height).toEqual('613px')        modal.unmount();    });    it('size', () => {        let com = getModal({ size: 'small', visible: true })        let modal = mount(com, { attachTo: document.getElementById('container') });        expect(modal.exists(`.${BASE_CLASS_PREFIX}-modal-small`)).toEqual(true);        // test medium size        modal.setProps({ size: 'medium' });        expect(modal.exists(`.${BASE_CLASS_PREFIX}-modal-medium`)).toEqual(true);        // test large size        modal.setProps({ size: 'large' });        expect(modal.exists(`.${BASE_CLASS_PREFIX}-modal-large`)).toEqual(true);        // test full-width        modal.setProps({ size: 'full-width' });        expect(modal.exists(`.${BASE_CLASS_PREFIX}-modal-full-width`)).toEqual(true);        modal.unmount();    });    it('closable', () => {        let closeCom = getModal({ closable: true, visible: true });        let nocloseCom = getModal({ closable: false, visible: true });        let modal = mount(closeCom, { attachTo: document.getElementById('container') });        expect(modal.exists(`.${BASE_CLASS_PREFIX}-modal-close`)).toEqual(true);        modal.unmount();        let notClosableSideSheet = mount(nocloseCom, { attachTo: document.getElementById('container') });        expect(notClosableSideSheet.exists(`.${BASE_CLASS_PREFIX}-modal-close`)).toEqual(false);        notClosableSideSheet.unmount();    });    it('getPopupContainer', () => {        let containedcom = (            <div                style={{                    height: 320,                    overflow: 'hidden',                    position: 'relative',                }}                className='modal-container'            >                <Modal                    visible={true}                    getPopupContainer={() => document.querySelector('.modal-container')}                />            </div>        )        let wrapper = mount(containedcom, { attachTo: document.getElementById('container') });        let container = document.querySelector('.modal-container').querySelector(`.${BASE_CLASS_PREFIX}-modal`);        expect(wrapper.find(`div.${BASE_CLASS_PREFIX}-modal`).html()).toEqual(container.outerHTML);    });    it('maskClosable', () => {        let onCancel = () => { };        let spyOnCancel = sinon.spy(onCancel);        let spyOnCancel2 = sinon.spy(onCancel);        let closeCom = getModal({            maskClosable: true,            visible: true,            onCancel: spyOnCancel        });        let modal = mount(closeCom, { attachTo: document.getElementById('container') });        // maskClosable        modal.find(`.${BASE_CLASS_PREFIX}-modal-wrap`).simulate('click');        expect(spyOnCancel.calledOnce).toBe(true);        modal.unmount();        // mask not closable        let notMaskClosableSideSheet = mount(getModal({            maskClosable: false,            visible: true,            onCancel: spyOnCancel2        }), { attachTo: document.getElementById('container') });        notMaskClosableSideSheet.find(`.${BASE_CLASS_PREFIX}-modal-wrap`).simulate('click');        expect(spyOnCancel2.calledOnce).toBe(false);        notMaskClosableSideSheet.unmount();    });    it('button props: cancelText / okText / okButtonProps / cancelButtonProps / hasCancel / confirmLoading ', () => {        let component = getModal({            cancelText: 'cancel',            okText: 'ok',            okType: 'secondary',            visible: true,            // remove close btn to avoid selected by selector            closable: false,        });        let modal = mount(component, { attachTo: document.getElementById('container') });        let footerBtn = modal.find(`.${BASE_CLASS_PREFIX}-button`)        expect(footerBtn.at(0).text()).toEqual('cancel');        expect(footerBtn.at(1).text()).toEqual('ok');        expect(footerBtn.at(1)).toHaveClassName(`${BASE_CLASS_PREFIX}-button-secondary`);        // test passing props        modal.setProps({            okButtonProps: { size: 'small', type: 'warning' },            cancelButtonProps: { size: 'small', disabled: true }        });        footerBtn = modal.find(`.${BASE_CLASS_PREFIX}-button`)        expect(footerBtn.at(0)).toHaveClassName(`${BASE_CLASS_PREFIX}-button-disabled ${BASE_CLASS_PREFIX}-button-size-small`);        expect(footerBtn.at(1)).toHaveClassName(`${BASE_CLASS_PREFIX}-button-warning ${BASE_CLASS_PREFIX}-button-size-small`);        // ok Btn loading, no cancel        modal.setProps({            hasCancel: false,            confirmLoading: true,        });        footerBtn = modal.find(`.${BASE_CLASS_PREFIX}-button`)        expect(footerBtn.length).toEqual(1);        expect(footerBtn.at(0)).toHaveClassName(`${BASE_CLASS_PREFIX}-button-loading`);    });    it('onCancel / onOk', () => {        // onCancel on close btn        // debugger        let onCancel = () => { };        let onOk = () => { };        let spyOnCancel = sinon.spy(onCancel);        let spyOnOk = sinon.spy(onOk);        let closeCom = getModal({            visible: true,            onCancel: spyOnCancel,            onOk: spyOnOk        });        let modal = mount(closeCom, { attachTo: document.getElementById('container') });        let btn = modal.find(`.${BASE_CLASS_PREFIX}-button`)        modal.find(`button.${BASE_CLASS_PREFIX}-modal-close`).simulate('click');        btn.at(1).simulate('click');        btn.at(2).simulate('click');        expect(spyOnCancel.calledTwice).toBe(true);        expect(spyOnOk.calledOnce).toBe(true);    });    it('no mask', () => {        let com = getModal({            mask: false,            visible: true,        });        let modal = mount(com, { attachTo: document.getElementById('container') });        expect(modal.exists(`.${BASE_CLASS_PREFIX}-modal-mask`)).toEqual(false);    });    it('closeIcon', () => {        let com = getModal({            visible: true,            closeIcon: (<IconEyeClosed />)        });        let modal = mount(com, { attachTo: document.getElementById('container') });        expect(modal.find(`.${BASE_CLASS_PREFIX}-icon-eye_closed`).length).toBe(1);    });    it('motion false', () => {        let com = getModal({ visible: true, motion: false });        let modal = mount(com, { attachTo: document.getElementById('container') });        expect(modal.find(`div.${BASE_CLASS_PREFIX}-modal`)).not.toHaveStyle('transform');        // visible false        modal.setProps({ visible: false });        modal.update(); // 必须调用一次update        expect(document.querySelector(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(null);    });    it('centered', (done) => {        let com = getModal({ centered: true, visible: true, motion: true });        let modal = mount(com, { attachTo: document.getElementById('container') });        setTimeout(() => {            modal.update();            expect(modal.find(`div.${BASE_CLASS_PREFIX}-modal-content`)).toHaveClassName(`semi-modal-content-animate-show`);            done();        }, 2000);    });    it('centered without motion', () => {        let com = getModal({ centered: true, visible: true, motion: false });        let modal = mount(com, { attachTo: document.getElementById('container') });        expect(modal.find(`div.${BASE_CLASS_PREFIX}-modal-wrap`)).toHaveClassName(`${BASE_CLASS_PREFIX}-modal-wrap-center`)    });    it('keepDOM', () => {        let component = getModal({ keepDOM: true });        let modal = mount(component, { attachTo: document.getElementById('container') });        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(false);        // set true        modal.setProps({ visible: true });        modal.update(); // 必须调用一次update        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(true);        expect(document.body.style.overflow).toEqual('hidden');        // set false but still exist        modal.setProps({ visible: false });        modal.update(); // 必须调用一次update        expect(modal.state().displayNone).toEqual(true);        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(true);    });    it('keepDOM + lazyRender=false', () => {        let component = getModal({ keepDOM: true, lazyRender: false });        let modal = mount(component, { attachTo: document.getElementById('container') });        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(true);        // set true        modal.setProps({ visible: true });        modal.update(); // 必须调用一次update        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(true);        expect(document.body.style.overflow).toEqual('hidden');        // set false but still exist        modal.setProps({ visible: false });        modal.update(); // 必须调用一次update        expect(modal.state().displayNone).toEqual(true);        expect(modal.exists(`div.${BASE_CLASS_PREFIX}-modal`)).toEqual(true);    });})
 |