Skip to content
This repository has been archived by the owner on Jun 26, 2020. It is now read-only.

Commit

Permalink
Merge pull request #33 from ckeditor/t/ckeditor5/1591
Browse files Browse the repository at this point in the history
Feature: `BalloonEditor.create()` will throw an error, when textarea element is used.
  • Loading branch information
jodator authored Jun 12, 2019
2 parents e2b5bfc + 6624119 commit 83552e2
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 36 deletions.
9 changes: 8 additions & 1 deletion src/ballooneditor.js
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,13 @@ export default class BalloonEditor extends Editor {
*/
static create( sourceElementOrData, config = {} ) {
return new Promise( resolve => {
const isHTMLElement = isElement( sourceElementOrData );

if ( isHTMLElement && sourceElementOrData.tagName === 'TEXTAREA' ) {
// Documented in core/editor/editor.js
throw new CKEditorError( 'editor-wrong-element: This type of editor cannot be initialized inside <textarea> element.' );
}

const editor = new this( sourceElementOrData, config );

resolve(
Expand All @@ -204,7 +211,7 @@ export default class BalloonEditor extends Editor {
editor.ui.init();
} )
.then( () => {
if ( !isElement( sourceElementOrData ) && config.initialData ) {
if ( !isHTMLElement && config.initialData ) {
// Documented in core/editor/editorconfig.jdoc.
throw new CKEditorError(
'editor-create-initial-data: ' +
Expand Down
64 changes: 29 additions & 35 deletions tests/ballooneditor.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
*/

/* globals document, Event */
/* globals document */

import BalloonEditorUI from '../src/ballooneditorui';
import BalloonEditorUIView from '../src/ballooneditoruiview';
Expand Down Expand Up @@ -75,37 +75,6 @@ describe( 'BalloonEditor', () => {
expect( editor.model.document.getRoot( 'main' ) ).to.instanceof( RootElement );
} );

it( 'handles form element', () => {
const form = document.createElement( 'form' );
const textarea = document.createElement( 'textarea' );
form.appendChild( textarea );
document.body.appendChild( form );

// Prevents page realods in Firefox ;|
form.addEventListener( 'submit', evt => {
evt.preventDefault();
} );

return BalloonEditor.create( textarea, {
plugins: [ Paragraph ]
} ).then( editor => {
expect( textarea.value ).to.equal( '' );

editor.setData( '<p>Foo</p>' );

form.dispatchEvent( new Event( 'submit', {
// We need to be able to do preventDefault() to prevent page reloads in Firefox.
cancelable: true
} ) );

expect( textarea.value ).to.equal( '<p>Foo</p>' );

return editor.destroy().then( () => {
form.remove();
} );
} );
} );

it( 'should have undefined the #sourceElement if editor was initialized with data', () => {
return BalloonEditor
.create( '<p>Foo.</p>', {
Expand Down Expand Up @@ -195,9 +164,19 @@ describe( 'BalloonEditor', () => {
BalloonEditor.create( '<p>Hello world!</p>', {
initialData: '<p>I am evil!</p>',
plugins: [ Paragraph ]
} ).catch( () => {
done();
} );
} )
.then(
() => {
expect.fail( 'Balloon editor should throw an error when both initial data are passed' );
},
err => {
expect( err ).to.be.an( 'error' ).with.property( 'message' ).and
// eslint-disable-next-line max-len
.match( /^editor-create-initial-data: The config\.initialData option cannot be used together with initial data passed in Editor\.create\(\)\./ );
}
)
.then( done )
.catch( done );
} );

// ckeditor/ckeditor5-editor-classic#53
Expand Down Expand Up @@ -226,6 +205,21 @@ describe( 'BalloonEditor', () => {
return newEditor.destroy();
} );
} );

it( 'throws an error when is initialized in textarea', done => {
BalloonEditor.create( document.createElement( 'textarea' ) )
.then(
() => {
expect.fail( 'Balloon editor should throw an error when is initialized in textarea.' );
},
err => {
expect( err ).to.be.an( 'error' ).with.property( 'message' ).and
.match( /^editor-wrong-element: This type of editor cannot be initialized inside <textarea> element\./ );
}
)
.then( done )
.catch( done );
} );
} );

describe( 'create - events', () => {
Expand Down

0 comments on commit 83552e2

Please sign in to comment.