ckeditor5-image-upload-base64
Version:
The development environment of CKEditor 5 – the best browser-based rich text editor.
62 lines (55 loc) • 1.68 kB
JavaScript
/**
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved.
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
*/
import Command from '@ckeditor/ckeditor5-core/src/command';
import { insertImage, isImageAllowed } from './utils';
/**
* @module image/image/imageinsertcommand
*/
/**
* Insert image command.
*
* The command is registered by the {@link module:image/image/imageediting~ImageEditing} plugin as `'imageInsert'`.
*
* In order to insert an image at the current selection position
* (according to the {@link module:widget/utils~findOptimalInsertionPosition} algorithm),
* execute the command and specify the image source:
*
* editor.execute( 'imageInsert', { source: 'http://url.to.the/image' } );
*
* It is also possible to insert multiple images at once:
*
* editor.execute( 'imageInsert', {
* source: [
* 'path/to/image.jpg',
* 'path/to/other-image.jpg'
* ]
* } );
*
* @extends module:core/command~Command
*/
export default class ImageInsertCommand extends Command {
/**
* @inheritDoc
*/
refresh() {
this.isEnabled = isImageAllowed( this.editor.model );
}
/**
* Executes the command.
*
* @fires execute
* @param {Object} options Options for the executed command.
* @param {String|Array.<String>} options.source The image source or an array of image sources to insert.
*/
execute( options ) {
const model = this.editor.model;
model.change( writer => {
const sources = Array.isArray( options.source ) ? options.source : [ options.source ];
for ( const src of sources ) {
insertImage( writer, model, { src } );
}
} );
}
}