Skip to content

Commit

Permalink
Release v0.2.0
Browse files Browse the repository at this point in the history
  • Loading branch information
Mgsy authored Dec 2, 2024
1 parent 764c6cd commit bbe30ba
Show file tree
Hide file tree
Showing 9 changed files with 110 additions and 106 deletions.
12 changes: 12 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,17 @@
# Changelog

## 0.2.0 (December 2, 2024)

We are happy to announce the release of CKEditor 5 Official Integration v0.2.0.

### Release highlights

In this release, we updated the CKEditor 5 version to [v44.0.0](https://github.com/ckeditor/ckeditor5/blob/master/CHANGELOG.md#4400-december-2-2024), which introduces high impact updates. Starting from the plugin version 0.2.0, the custom field will require passing a valid license key.

### BREAKING CHANGES ℹ️

* **CKEditor 5 custom field now requires the license key**. CKEditor 5 now requires a valid license key, which can be retrieved from [Customer Portal](https://portal.ckeditor.com/). You can sign up for a [commitment-free trial](https://portal.ckeditor.com/checkout?plan=free) and get instant access to your key.

## 0.1.0 (September 19, 2024)

We are happy to announce the release of CKEditor 5 Official Integration v0.1.0.
Expand Down
8 changes: 6 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ This is an official plugin, provided to you by the [CKEditor team](https://ckedi

## <a id="installation"></a>🔧 Installation

> [!IMPORTANT]
> Before installation, make sure that you own a **valid CKEditor 5 license key**. Start a [commitment-free trial](https://portal.ckeditor.com/checkout?plan=free) to get instant access to the license key. You can also refer to our [license key and activation guide](https://ckeditor.com/docs//ckeditor5/latest/getting-started/licensing/license-key-and-activation.html) to learn more.
Inside your Strapi app, add the package:

With `npm`:
Expand All @@ -36,7 +39,7 @@ With `yarn`:
yarn add @ckeditor/strapi-plugin-ckeditor
```

Then, add the Content Security Policy configuration to allow loading CKEditor 5 from https://cdn.ckeditor.com origin, by adding the rule to `config/middlewares.ts` in your Strapi project root:
Then, add the Content Security Policy configuration to allow loading CKEditor 5 from https://cdn.ckeditor.com origin and sending the editor usage information to https://proxy-event.ckeditor.com, by adding the rule to `config/middlewares.ts` in your Strapi project root:

```js
export default [
Expand All @@ -47,7 +50,8 @@ export default [
contentSecurityPolicy: {
useDefaults: true,
directives: {
'script-src': ['https://cdn.ckeditor.com']
'script-src': ['https://cdn.ckeditor.com'],
'connect-src': ['https://proxy-event.ckeditor.com']
},
},
},
Expand Down
13 changes: 10 additions & 3 deletions admin/src/components/CKEditorInput/Configurator.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { StrapiMediaLib } from "./plugins/StrapiMediaLib";
import { StrapiEditorUsageDataPlugin } from "./plugins/StrapiEditorUsageData.js";

import MaximumLength from "../../vendor/ckeditor5-maximum-length/index";
import "../../vendor/ckeditor5-maximum-length/index-editor.css";
Expand Down Expand Up @@ -77,7 +78,8 @@ const CKEDITOR_BASE_CONFIG_FOR_PRESETS = {
TableColumnResize,
TableCaption,
WordCount,
StrapiMediaLib
StrapiMediaLib,
StrapiEditorUsageDataPlugin
],
toolbar: [
'undo', 'redo',
Expand Down Expand Up @@ -146,7 +148,8 @@ const CKEDITOR_BASE_CONFIG_FOR_PRESETS = {
TableColumnResize,
TableCaption,
WordCount,
StrapiMediaLib
StrapiMediaLib,
StrapiEditorUsageDataPlugin
],
toolbar: [
'undo', 'redo',
Expand Down Expand Up @@ -240,7 +243,8 @@ const CKEDITOR_BASE_CONFIG_FOR_PRESETS = {
TableCaption,
WordCount,
Highlight,
StrapiMediaLib
StrapiMediaLib,
StrapiEditorUsageDataPlugin
],
toolbar: {
items: [
Expand Down Expand Up @@ -372,6 +376,9 @@ export default class Configurator {

const maxLength = this.fieldConfig.maxLength;
const outputOption = this.fieldConfig.options.output;
const licenseKey = this.fieldConfig.licenseKey;

config.licenseKey = licenseKey;

if ( outputOption === 'Markdown' ) {
config.plugins.push( Markdown );
Expand Down
6 changes: 3 additions & 3 deletions admin/src/components/CKEditorInput/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,8 @@ const CKEditorInput = ( props ) => {
} = props;
const [ editorInstance, setEditorInstance ] = useState(false);
const { formatMessage } = useIntl();
const { maxLengthCharacters:maxLength , ...options } = attribute.options;
const configurator = new Configurator( { options, maxLength } );
const { maxLengthCharacters:maxLength, licenseKey, ...options } = attribute.options;
const configurator = new Configurator( { options, maxLength, licenseKey } );
const editorConfig = configurator.getEditorConfig();

const wordCounter = useRef( null );
Expand Down Expand Up @@ -132,4 +132,4 @@ CKEditorInput.propTypes = {
value: PropTypes.string,
};

export default CKEditorInput;
export { CKEditorInput };
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { createIntegrationUsageDataPlugin } from '@ckeditor/ckeditor5-integrations-common';
import * as pkg from '../../../../../package.json'

export const StrapiEditorUsageDataPlugin = createIntegrationUsageDataPlugin(
'strapi',
{
version: pkg.version,
}
);
128 changes: 42 additions & 86 deletions admin/src/components/CKEditorProvider/index.js
Original file line number Diff line number Diff line change
@@ -1,98 +1,54 @@
import { useState, useEffect } from 'react';
import { memo, useEffect } from 'react';
import { useCKEditorCloud } from '@ckeditor/ckeditor5-react';

const CKEditorProvider = ( {
attribute,
onChange,
name,
value,
disabled = false,
labelAction = null,
intlLabel,
required = false,
description = null,
error = null
} ) => {
const [ importedEditor, setImportedEditor ] = useState( null );

attribute,
onChange,
name,
value,
disabled = false,
labelAction = null,
intlLabel,
required = false,
description = null,
error = null } ) => {

// Clean up CDN scripts after unmounting the component.
useEffect( () => {
const importEditor = async () => {
const module = await import( '../CKEditorInput' );
const CKEditorInput = module.default;

setImportedEditor(<CKEditorInput
attribute={ attribute }
onChange={ onChange }
name={ name }
value={ value }
disabled={ disabled }
labelAction={ labelAction }
required={ required }
description={ description }
error={ error }
intlLabel={ intlLabel }
/> );
};

const injectAssetsFromCDN = setInterval( () => {
const CDNScript = document.querySelector( '#ckeditor5-cdn-script' );
const CDNStyles = document.querySelector( '#ckeditor5-cdn-styles' );

if ( !CDNStyles ) {
_injectStylesFromCDN();
}

if ( window.CKEDITOR ) {
window.CKEditorCDNLoaded = true;

importEditor();

clearInterval( injectAssetsFromCDN );

return;
}

if ( !CDNScript ) {
_injectScriptFromCDN();

}
}, 100 )

return () => {
const CDNScript = document.querySelector( '#ckeditor5-cdn-script' );
const assets = document.querySelectorAll( '[data-injected-by="ckeditor-integration"]' );

if ( CDNScript ) {
CDNScript.remove();
}
assets.forEach( asset => asset.remove() );

window.CKEditorCDNLoaded = false;
window.CKEDITOR_VERSION = null;
}
}, [] );
}, [] )

return (
<>
{ window.CKEditorCDNLoaded && importedEditor }
</>
)
}

function _injectStylesFromCDN() {
const link = document.createElement( 'link' );

link.rel = 'stylesheet';
link.href = 'https://cdn.ckeditor.com/ckeditor5/43.0.0/ckeditor5.css';
link.id = 'ckeditor5-cdn-styles';

document.head.appendChild( link );
}

function _injectScriptFromCDN() {
const script = document.createElement( 'script' );
const cloud = useCKEditorCloud( {
version: '44.0.0',
plugins: {
CKEditorInput: async () => ( await import('../CKEditorInput') ).CKEditorInput
}
} );

script.src = "https://cdn.ckeditor.com/ckeditor5/43.0.0/ckeditor5.umd.js";
script.async = true;
script.id = 'ckeditor5-cdn-script'
if ( cloud.status !== 'success' ) {
return null;
}

document.body.appendChild( script );
return (
<cloud.loadedPlugins.CKEditorInput
attribute={ attribute }
onChange={ onChange }
name={ name }
value={ value }
disabled={ disabled }
labelAction={ labelAction }
required={ required }
description={ description }
error={ error }
intlLabel={ intlLabel }
/>
)
}

export default CKEditorProvider;
export default memo( CKEditorProvider );
16 changes: 16 additions & 0 deletions admin/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,18 @@ export default {
},
options: {
base: [
{
intlLabel: {
id: 'ckeditor.licenseKey.label',
defaultMessage: 'License key',
},
description: {
id: 'ckeditor.licenseKey.description',
defaultMessage: "Don't have a license key? Visit https://portal.ckeditor.com/checkout?plan=free to receive it.",
},
name: 'options.licenseKey',
type: 'text',
},
{
intlLabel: {
id: 'ckeditor.preset.label',
Expand Down Expand Up @@ -157,6 +169,10 @@ export default {
id: 'ckeditor.preset.error.required',
defaultMessage: 'Editor preset is required',
} ),
licenseKey: yup.string().required( {
id: 'ckeditor.licenseKey.error.required',
defaultMessage: 'Editor license key is required. Visit https://portal.ckeditor.com/checkout?plan=free to receive it.',
} ),
} ),
},
} );
Expand Down
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@ckeditor/strapi-plugin-ckeditor",
"version": "0.1.0",
"version": "0.2.0",
"description": "CKEditor 5 - Official Integration for Strapi.",
"strapi": {
"name": "ckeditor",
Expand All @@ -24,7 +24,7 @@
"strapi-server.js"
],
"dependencies": {
"@ckeditor/ckeditor5-react": "^9.1.0"
"@ckeditor/ckeditor5-react": "^9.3.0"
},
"peerDependencies": {
"@strapi/strapi": "^4.4.0"
Expand Down
20 changes: 10 additions & 10 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,17 @@
# yarn lockfile v1


"@ckeditor/ckeditor5-integrations-common@^1.0.0":
version "1.0.0"
resolved "https://registry.yarnpkg.com/@ckeditor/ckeditor5-integrations-common/-/ckeditor5-integrations-common-1.0.0.tgz#f2f73509d029398929ee30da3ae23329de5a796a"
integrity sha512-HLToIJ7FAtKX0tu9GaGb1d39Kx0i0TFelAj2pQPiwPU/6DLgM5gi+m0WCZub+syruSonmZPONtWrrZZdUoDB/g==

"@ckeditor/ckeditor5-react@^9.1.0":
version "9.1.0"
resolved "https://registry.yarnpkg.com/@ckeditor/ckeditor5-react/-/ckeditor5-react-9.1.0.tgz#fc645a055a5c84acb41c55f0c4bffab45221d2ca"
integrity sha512-48Y8Ffe21H3+3GOvjTtSITYJdeX4BINxCHyXp5zNvhTtyAyahMwG6jCgdZl1D3lwXxSq9R0/yCDHPWeMk9KOHQ==
"@ckeditor/ckeditor5-integrations-common@^2.2.2":
version "2.2.2"
resolved "https://registry.yarnpkg.com/@ckeditor/ckeditor5-integrations-common/-/ckeditor5-integrations-common-2.2.2.tgz#c494b51ad0736d087a7bc13ec634e2d66db42d5b"
integrity sha512-SKGBBrwFFmSEZawR8P9tHGRq/l2OoqoJxy9f7j0HbDGEwIpSOsCSgH0xudD6lcEbWG4QWrCS28p5n8lgPA5elQ==

"@ckeditor/ckeditor5-react@^9.3.0":
version "9.4.0"
resolved "https://registry.yarnpkg.com/@ckeditor/ckeditor5-react/-/ckeditor5-react-9.4.0.tgz#2d750ed585a4668931be089da7a02e823c706f16"
integrity sha512-8PU7YUV0ZKYP10akKgarT8nq5QxEDPmuj6Wn5dl/DJ7qroDx6VuC/ysCYcgljseimbDNYDjPQKhatNEcsMd7Ew==
dependencies:
"@ckeditor/ckeditor5-integrations-common" "^1.0.0"
"@ckeditor/ckeditor5-integrations-common" "^2.2.2"
prop-types "^15.7.2"

"js-tokens@^3.0.0 || ^4.0.0":
Expand Down

0 comments on commit bbe30ba

Please sign in to comment.