|
3 | 3 | * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
|
4 | 4 | */
|
5 | 5 |
|
6 |
| -/* globals document, console */ |
| 6 | +/* globals document, console, setTimeout */ |
7 | 7 |
|
8 | 8 | import View from '../../../src/view/view';
|
9 | 9 | import Observer from '../../../src/view/observer/observer';
|
@@ -514,6 +514,64 @@ describe( 'view', () => {
|
514 | 514 | } );
|
515 | 515 | } );
|
516 | 516 |
|
| 517 | + describe( 'hasDomSelection', () => { |
| 518 | + let domElement, domP, domSelection; |
| 519 | + |
| 520 | + beforeEach( () => { |
| 521 | + const viewRoot = createViewRoot( viewDocument, 'div', 'main' ); |
| 522 | + |
| 523 | + view.attachDomRoot( domRoot ); |
| 524 | + |
| 525 | + viewRoot._appendChild( new ViewElement( viewDocument, 'p' ) ); |
| 526 | + view.forceRender(); |
| 527 | + |
| 528 | + domElement = createElement( document, 'div', { contenteditable: 'true' } ); |
| 529 | + document.body.appendChild( domElement ); |
| 530 | + |
| 531 | + domSelection = document.getSelection(); |
| 532 | + domP = domRoot.childNodes[ 0 ]; |
| 533 | + } ); |
| 534 | + |
| 535 | + afterEach( () => { |
| 536 | + domElement.remove(); |
| 537 | + } ); |
| 538 | + |
| 539 | + it( 'should be true if selection is inside a DOM root element', done => { |
| 540 | + domSelection.collapse( domP, 0 ); |
| 541 | + |
| 542 | + // Wait for async selectionchange event on DOM document. |
| 543 | + setTimeout( () => { |
| 544 | + expect( view.hasDomSelection ).to.be.true; |
| 545 | + |
| 546 | + done(); |
| 547 | + }, 100 ); |
| 548 | + } ); |
| 549 | + |
| 550 | + it( 'should be true if selection is inside a DOM root element - no focus', done => { |
| 551 | + domSelection.collapse( domP, 0 ); |
| 552 | + domRoot.blur(); |
| 553 | + |
| 554 | + // Wait for async selectionchange event on DOM document. |
| 555 | + setTimeout( () => { |
| 556 | + expect( view.hasDomSelection ).to.be.true; |
| 557 | + expect( view.document.isFocused ).to.be.false; |
| 558 | + |
| 559 | + done(); |
| 560 | + }, 100 ); |
| 561 | + } ); |
| 562 | + |
| 563 | + it( 'should be false if selection is outside DOM root element', done => { |
| 564 | + domSelection.collapse( domElement, 0 ); |
| 565 | + |
| 566 | + // Wait for async selectionchange event on DOM document. |
| 567 | + setTimeout( () => { |
| 568 | + expect( view.hasDomSelection ).to.be.false; |
| 569 | + |
| 570 | + done(); |
| 571 | + }, 100 ); |
| 572 | + } ); |
| 573 | + } ); |
| 574 | + |
517 | 575 | describe( 'forceRender()', () => {
|
518 | 576 | it( 'disable observers, renders and enable observers', () => {
|
519 | 577 | const observerMock = view.addObserver( ObserverMock );
|
|
0 commit comments