CKEditor 5 iframe feature ·
data:image/s3,"s3://crabby-images/584c7/584c7479d3709103aaf242e26b1900a9defd2e73" alt="npm version"
ckeditor5-iframe is based on CKEditor 5's HTML
embed
Plugin (NPM)
Renders links to <iframe src="...">
data:image/s3,"s3://crabby-images/abafd/abafdb0243ad6d300661da8cc21fc456a8577305" alt="ckeditor5-iframe in a classic build ckeditor5-iframe in a classic build."
Table of contents
Installation
via npm:
npm install ckeditor5-iframe --save-dev
via yarn:
yarn install ckeditor5-iframe --dev
Configuration
In your editor build / configuration:
import IframeEmbed from "ckeditor5-iframe/src/iframeembed";
ClassicEditor.create(document.querySelector("#editor"), {
plugins: [Essentials, Paragraph, Bold, Italic, IframeEmbed],
toolbar: ["bold", "italic", "iframeEmbed"],
});
Show previews
data:image/s3,"s3://crabby-images/a5fa7/a5fa7cf41856832263dc6f1112a0996c231b7f89" alt="Screenshot of the in-editor
preview Preview option"
Passing true
to iframeEmbed.showPreviews
will enable previewing.
import IframeEmbed from "ckeditor5-iframe/src/iframeembed";
ClassicEditor.create(document.querySelector("#editor"), {
plugins: [Essentials, Paragraph, Bold, Italic, IframeEmbed],
toolbar: ["bold", "italic", "iframeEmbed"],
iframeEmbed: {
showPreviews: true,
},
});
The minimum dimensions are tweakable via CSS variables --ck-iframe-embed-content-min-height
and --ck-iframe-embed-content-min-width
.
Input format
<figure class="iframe-embed">
<iframe src="https://www.google.com">
</figure>
Development
To boot up a development loop, clone the repo, install the packages via yarn
, yarn start
and go to http://localhost:8080
data:image/s3,"s3://crabby-images/5e059/5e059c087c4b6df42c0dab74f7509f5c7b6c0c67" alt="Screenshot of dev environment Dev environment"
From here, you can customize demo/
's app.js
and index.html
as well as
files inside src/
(the plugin code itself) and files will be automatically
rebuilt. You still may need to refresh.
The window.editor
can access the
ClassicEditor
object, e.g. editor.getData()
can retrieve the output HTML.
Credits
Icon: https://iconify.design/icon-sets/mdi/iframe.html, Open Font License