UNPKG

ckeditor5-image-upload-base64

Version:

The development environment of CKEditor 5 – the best browser-based rich text editor.

61 lines (51 loc) 1.92 kB
/** * @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license */ /** * @module enter/enterobserver */ import Observer from '@ckeditor/ckeditor5-engine/src/view/observer/observer'; import DomEventData from '@ckeditor/ckeditor5-engine/src/view/observer/domeventdata'; import { keyCodes } from '@ckeditor/ckeditor5-utils/src/keyboard'; /** * Enter observer introduces the {@link module:engine/view/document~Document#event:enter} event. * * @extends module:engine/view/observer/observer~Observer */ export default class EnterObserver extends Observer { constructor( view ) { super( view ); const doc = this.document; doc.on( 'keydown', ( evt, data ) => { if ( this.isEnabled && data.keyCode == keyCodes.enter ) { // Save the event object to check later if it was stopped or not. let event; doc.once( 'enter', evt => ( event = evt ), { priority: 'highest' } ); doc.fire( 'enter', new DomEventData( doc, data.domEvent, { isSoft: data.shiftKey } ) ); // Stop `keydown` event if `enter` event was stopped. // https://github.com/ckeditor/ckeditor5/issues/753 if ( event && event.stop.called ) { evt.stop(); } } } ); } /** * @inheritDoc */ observe() {} } /** * Event fired when the user presses the <kbd>Enter</kbd> key. * * Note: This event is fired by the {@link module:enter/enterobserver~EnterObserver observer} * (usually registered by the {@link module:enter/enter~Enter Enter feature} and * {@link module:enter/shiftenter~ShiftEnter ShiftEnter feature}). * * @event module:engine/view/document~Document#event:enter * @param {module:engine/view/observer/domeventdata~DomEventData} data * @param {Boolean} data.isSoft Whether it's a soft enter (<kbd>Shift</kbd>+<kbd>Enter</kbd>) or hard enter (<kbd>Enter</kbd>). */