|
1 | 1 | import React from 'react'; |
2 | 2 | import { mount } from 'enzyme'; |
| 3 | +import Portal from 'rc-util/lib/Portal'; |
3 | 4 | import Trigger from '../src'; |
4 | 5 |
|
5 | 6 | const autoAdjustOverflow = { |
@@ -382,6 +383,43 @@ describe('Trigger.Basic', () => { |
382 | 383 | }); |
383 | 384 | }); |
384 | 385 |
|
| 386 | + describe('support autoDestroy', () => { |
| 387 | + it('defaults to false', () => { |
| 388 | + const wrapper = mount( |
| 389 | + <Trigger |
| 390 | + action={['click']} |
| 391 | + popupAlign={placementAlignMap.topRight} |
| 392 | + popup={<strong>trigger</strong>} |
| 393 | + > |
| 394 | + <div className="target">click</div> |
| 395 | + </Trigger>, |
| 396 | + ); |
| 397 | + expect(wrapper.prop('autoDestroy')).toBeFalsy(); |
| 398 | + wrapper.trigger(); |
| 399 | + expect(wrapper.find(Portal).exists()).toBe(true); |
| 400 | + wrapper.trigger(); |
| 401 | + expect(wrapper.find(Portal).exists()).toBe(true); |
| 402 | + }); |
| 403 | + |
| 404 | + it('set true will destroy portal on hide', () => { |
| 405 | + const wrapper = mount( |
| 406 | + <Trigger |
| 407 | + action={['click']} |
| 408 | + autoDestroy |
| 409 | + popupAlign={placementAlignMap.topRight} |
| 410 | + popup={<strong>trigger</strong>} |
| 411 | + > |
| 412 | + <div className="target">click</div> |
| 413 | + </Trigger>, |
| 414 | + ); |
| 415 | + |
| 416 | + wrapper.trigger(); |
| 417 | + expect(wrapper.find(Portal).exists()).toBe(true); |
| 418 | + wrapper.trigger(); |
| 419 | + expect(wrapper.find(Portal).exists()).toBe(false); |
| 420 | + }); |
| 421 | + }); |
| 422 | + |
385 | 423 | describe('github issues', () => { |
386 | 424 | // https://github.com/ant-design/ant-design/issues/9114 |
387 | 425 | it('click in popup of popup', () => { |
|
0 commit comments