Migrating Angular CKEditor 5 integration from npm to CDN
This guide will help you migrate Angular CKEditor 5 integration from an NPM-based installation to a CDN-based one.
# Prerequisites
Remove the existing CKEditor 5 packages from your project. If you are using the NPM-based installation, you can remove it by running the following command:
npm uninstall ckeditor5 ckeditor5-premium-features
Upgrade the CKEditor 5 Angular integration to the latest version. You can find it in the Angular integration documentation.
Ensure that your testing suite uses real web browser environments for testing. If you are using jsdom
or any other environment without a real DOM, you may need to adjust the testing suite configuration to use a real browser because CDN script injection might not be recognized properly in such environments.
# Migration steps
# Step 1: Remove CKEditor 5 imports
If you have any CKEditor 5 imports in your Angular components, remove them. For example, remove lines like:
import { ClassicEditor, /* ... other imports */ } from 'ckeditor5';
import { AIAdapter, /* ... other imports */ } from 'ckeditor5-premium-features';
# Step 2: Update your Angular components to use CDN
Replace the CKEditor 5 NPM package imports with the CDN script imports and use the loadCKEditorCloud
function to load the CKEditor 5 scripts. The loadCKEditorCloud
function is a part of the @ckeditor/ckeditor5-angular
package and is used to load CKEditor 5 scripts from the CKEditor Cloud service.
Before:
// app.component.ts
import { Component, ViewEncapsulation } from '@angular/core';
import { CKEditorModule } from '@ckeditor/ckeditor5-angular';
import { ClassicEditor, Bold, Essentials, Italic, Mention, Paragraph, Undo } from 'ckeditor5';
import { SlashCommand } from 'ckeditor5-premium-features';
@Component( {
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
encapsulation: ViewEncapsulation.None,
imports: [ CKEditorModule ],
standalone: true
} )
export class AppComponent {
title = 'angular';
public Editor = ClassicEditor;
public config = {
licenseKey: '<YOUR_LICENSE_KEY>', // Or 'GPL'.
plugins: [ Bold, Essentials, Italic, Mention, Paragraph, SlashCommand, Undo ],
toolbar: [ 'undo', 'redo', '|', 'bold', 'italic' ],
// ... Other configuration ....
}
}
After:
// app.component.ts
import { Component, ViewEncapsulation } from '@angular/core';
import { CKEditorModule } from '@ckeditor/ckeditor5-angular';
@Component( {
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
encapsulation: ViewEncapsulation.None,
imports: [ CKEditorModule ],
standalone: true
} )
export class AppComponent {
title = 'angular';
public Editor;
public config;
public ngOnInit() {
// ADDED
loadCKEditorCloud( {
version: '43.0.0'
} )
.then( this._setupEditor.bind( this ) );
}
private _setupEditor( cloud ) {
const {
ClassicEditor, Bold, Essentials, Italic,
Mention, Paragraph, SlashCommand, Undo
} = cloud.CKEditor;
this.Editor = ClassicEditor;
this.config = {
licenseKey: '<YOUR_LICENSE_KEY>',
plugins: [ Bold, Essentials, Italic, Mention, Paragraph, SlashCommand, Undo ],
toolbar: [ 'undo', 'redo', '|', 'bold', 'italic' ],
// ... Other configuration ....
}
}
}
// app.component.html
<ckeditor
*ngIf="Editor"
[editor]="Editor"
[config]="config"
<!-- ... -->
>
</ckeditor>
# Step 3 (Optional): Migrate the CKEditor 5 Angular integration testing suite
If you have any tests that use CKEditor 5 objects, you need to update them to use the loadCKEditorCloud
function. Here is an example of migrating a test that uses the ClassicEditor
object:
Before:
import { ClassicEditor, /* ... other imports */ } from 'ckeditor5';
it( 'ClassicEditor test', () => {
// Your test that uses the CKEditor 5 object.
} );
After:
import { loadCKEditorCloud } from '@ckeditor/ckeditor5-angular';
let cloud;
beforeEach( async () => {
cloud = await loadCKEditorCloud( {
version: '44.1.0',
} );
} );
it( 'ClassicEditor test', () => {
const { ClassicEditor, /* ... other imports */ } = cloud.CKEditor;
// Your test that uses the CKEditor 5 object.
} );
# Step 4 (Optional): Clean up the document head entries before each test
If you use a testing suite that does not clean up the document head entries before each test, you may need to do it manually. It is essential because the CKEditor 5 CDN script will inject the editor into the head section of your HTML file and, you need to ensure that the head section is clean before each test.
However, there is one downside to this approach. Cleaning up the head entries before each test may slow down the test execution because the browser needs to download the CKEditor 5 script each time. In most cases, this should not be a problem, but if you notice that your tests are running slower, you may need to consider other solutions.
Here is an example of how you can Clean up the document head entries before each test:
import { removeAllCkCdnResources } from '@ckeditor/ckeditor5-integrations-common/test-utils';
beforeEach( () => {
removeAllCkCdnResources();
} );
Every day, we work hard to keep our documentation complete. Have you spotted outdated information? Is something missing? Please report it via our issue tracker.
With the release of version 42.0.0, we have rewritten much of our documentation to reflect the new import paths and features. We appreciate your feedback to help us ensure its accuracy and completeness.