Skip to content

Commit

Permalink
Merge branch i/6202-remove-env.isEdge to master.
Browse files Browse the repository at this point in the history
Internal: Removed mentions on Edge. See #6202.
  • Loading branch information
Reinmar committed Apr 20, 2020
2 parents 414f64b + 2d8bdc3 commit 70302b9
Show file tree
Hide file tree
Showing 4 changed files with 7 additions and 65 deletions.
23 changes: 7 additions & 16 deletions packages/ckeditor5-widget/src/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@

import HighlightStack from './highlightstack';
import IconView from '@ckeditor/ckeditor5-ui/src/icon/iconview';
import env from '@ckeditor/ckeditor5-utils/src/env';

import dragHandleIcon from '../theme/icons/drag-handle.svg';

Expand Down Expand Up @@ -90,11 +89,7 @@ export function isWidget( node ) {
*/
/* eslint-enable max-len */
export function toWidget( element, writer, options = {} ) {
// The selection on Edge behaves better when the whole editor contents is in a single contenteditable element.
// https://github.com/ckeditor/ckeditor5/issues/1079
if ( !env.isEdge ) {
writer.setAttribute( 'contenteditable', 'false', element );
}
writer.setAttribute( 'contenteditable', 'false', element );

writer.addClass( WIDGET_CLASS_NAME, element );
writer.setCustomProperty( 'widget', true, element );
Expand Down Expand Up @@ -220,17 +215,13 @@ export function getLabel( element ) {
export function toWidgetEditable( editable, writer ) {
writer.addClass( [ 'ck-editor__editable', 'ck-editor__nested-editable' ], editable );

// The selection on Edge behaves better when the whole editor contents is in a single contentedible element.
// https://github.com/ckeditor/ckeditor5/issues/1079
if ( !env.isEdge ) {
// Set initial contenteditable value.
writer.setAttribute( 'contenteditable', editable.isReadOnly ? 'false' : 'true', editable );
// Set initial contenteditable value.
writer.setAttribute( 'contenteditable', editable.isReadOnly ? 'false' : 'true', editable );

// Bind the contenteditable property to element#isReadOnly.
editable.on( 'change:isReadOnly', ( evt, property, is ) => {
writer.setAttribute( 'contenteditable', is ? 'false' : 'true', editable );
} );
}
// Bind the contenteditable property to element#isReadOnly.
editable.on( 'change:isReadOnly', ( evt, property, is ) => {
writer.setAttribute( 'contenteditable', is ? 'false' : 'true', editable );
} );

editable.on( 'change:isFocused', ( evt, property, is ) => {
if ( is ) {
Expand Down
43 changes: 0 additions & 43 deletions packages/ckeditor5-widget/tests/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ import {
WIDGET_CLASS_NAME
} from '../src/utils';
import UIElement from '@ckeditor/ckeditor5-engine/src/view/uielement';
import env from '@ckeditor/ckeditor5-utils/src/env';
import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils';
import Model from '@ckeditor/ckeditor5-engine/src/model/model';
import { setData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model';
Expand All @@ -37,9 +36,6 @@ describe( 'widget utils', () => {
testUtils.createSinonSandbox();

beforeEach( () => {
// Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`.
testUtils.sinon.stub( env, 'isEdge' ).get( () => false );

viewDocument = new ViewDocument();
writer = new DowncastWriter( viewDocument );

Expand Down Expand Up @@ -126,19 +122,6 @@ describe( 'widget utils', () => {
expect( icon.classList.contains( 'ck' ) ).to.be.true;
expect( icon.classList.contains( 'ck-icon' ) ).to.be.true;
} );

describe( 'on Edge', () => {
beforeEach( () => {
testUtils.sinon.stub( env, 'isEdge' ).get( () => true );

element = writer.createContainerElement( 'div' );
toWidget( element, writer );
} );

it( 'should not set contenteditable onEdge', () => {
expect( element.getAttribute( 'contenteditable' ) ).to.be.undefined;
} );
} );
} );

describe( 'isWidget()', () => {
Expand Down Expand Up @@ -220,32 +203,6 @@ describe( 'widget utils', () => {
element.isFocused = false;
expect( element.hasClass( 'ck-editor__nested-editable_focused' ) ).to.be.false;
} );

describe( 'on Edge', () => {
beforeEach( () => {
testUtils.sinon.stub( env, 'isEdge' ).get( () => true );

viewDocument = new ViewDocument();
element = new ViewEditableElement( viewDocument, 'div' );
toWidgetEditable( element, writer );
} );

it( 'should add contenteditable attribute when element is read-only - initialization', () => {
const element = new ViewEditableElement( viewDocument, 'div' );
element.isReadOnly = true;
toWidgetEditable( element, writer );

expect( element.getAttribute( 'contenteditable' ) ).to.be.undefined;
} );

it( 'should add contenteditable attribute when element is read-only - when changing', () => {
element.isReadOnly = true;
expect( element.getAttribute( 'contenteditable' ) ).to.be.undefined;

element.isReadOnly = false;
expect( element.getAttribute( 'contenteditable' ) ).to.be.undefined;
} );
} );
} );

describe( 'addHighlightHandling()', () => {
Expand Down
2 changes: 0 additions & 2 deletions packages/ckeditor5-widget/tests/widget-integration.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,6 @@ describe( 'Widget - integration', () => {
testUtils.createSinonSandbox();

beforeEach( () => {
// Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`.
testUtils.sinon.stub( env, 'isEdge' ).get( () => false );
testUtils.sinon.stub( env, 'isSafari' ).get( () => true );

editorElement = document.createElement( 'div' );
Expand Down
4 changes: 0 additions & 4 deletions packages/ckeditor5-widget/tests/widget.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ import DomEventData from '@ckeditor/ckeditor5-engine/src/view/observer/domeventd
import { setData as setModelData, getData as getModelData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model';
import { getData as getViewData } from '@ckeditor/ckeditor5-engine/src/dev-utils/view';
import { keyCodes } from '@ckeditor/ckeditor5-utils/src/keyboard';
import env from '@ckeditor/ckeditor5-utils/src/env';
import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils';

/* global document */
Expand All @@ -23,9 +22,6 @@ describe( 'Widget', () => {
testUtils.createSinonSandbox();

beforeEach( () => {
// Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`.
testUtils.sinon.stub( env, 'isEdge' ).get( () => false );

return VirtualTestEditor.create( { plugins: [ Widget, Typing ] } )
.then( newEditor => {
editor = newEditor;
Expand Down

0 comments on commit 70302b9

Please sign in to comment.