@ckeditor/ckeditor5-clipboard
Version:
Clipboard integration feature for CKEditor 5.
67 lines (66 loc) • 1.98 kB
JavaScript
/**
* @license Copyright (c) 2003-2025, CKSource Holding sp. z o.o. All rights reserved.
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
*/
/**
* @module clipboard/clipboard
*/
import { Plugin } from '@ckeditor/ckeditor5-core';
import ClipboardPipeline from './clipboardpipeline.js';
import DragDrop from './dragdrop.js';
import PastePlainText from './pasteplaintext.js';
import ClipboardMarkersUtils from './clipboardmarkersutils.js';
/**
* The clipboard feature.
*
* Read more about the clipboard integration in the {@glink framework/deep-dive/clipboard clipboard deep-dive} guide.
*
* This is a "glue" plugin which loads the following plugins:
* * {@link module:clipboard/clipboardpipeline~ClipboardPipeline}
* * {@link module:clipboard/dragdrop~DragDrop}
* * {@link module:clipboard/pasteplaintext~PastePlainText}
*/
export default class Clipboard extends Plugin {
/**
* @inheritDoc
*/
static get pluginName() {
return 'Clipboard';
}
/**
* @inheritDoc
*/
static get isOfficialPlugin() {
return true;
}
/**
* @inheritDoc
*/
static get requires() {
return [ClipboardMarkersUtils, ClipboardPipeline, DragDrop, PastePlainText];
}
/**
* @inheritDoc
*/
init() {
const editor = this.editor;
const t = this.editor.t;
// Add the information about the keystrokes to the accessibility database.
editor.accessibility.addKeystrokeInfos({
keystrokes: [
{
label: t('Copy selected content'),
keystroke: 'CTRL+C'
},
{
label: t('Paste content'),
keystroke: 'CTRL+V'
},
{
label: t('Paste content as plain text'),
keystroke: 'CTRL+SHIFT+V'
}
]
});
}
}