diff --git a/.yarn/cache/@ckeditor-ckeditor5-engine-patch-dfc8c266c9-0ca241d6d2.zip b/.yarn/cache/@ckeditor-ckeditor5-engine-patch-dfc8c266c9-0ca241d6d2.zip new file mode 100644 index 0000000000..303f1a6d5e Binary files /dev/null and b/.yarn/cache/@ckeditor-ckeditor5-engine-patch-dfc8c266c9-0ca241d6d2.zip differ diff --git a/package.json b/package.json index 162b50448e..9e88f177c6 100644 --- a/package.json +++ b/package.json @@ -9,7 +9,8 @@ "moment": "^2.20.1", "vfile-message": "^2.0.2", "isemail@3.2.0": "patch:isemail@npm:3.2.0#./patches/isemail-npm-3.2.0-browserified.patch", - "react-codemirror2@7.2.1": "patch:react-codemirror2@npm:7.2.1#./patches/react-codemirror2-npm-7.2.1-browserified.patch" + "react-codemirror2@7.2.1": "patch:react-codemirror2@npm:7.2.1#./patches/react-codemirror2-npm-7.2.1-browserified.patch", + "@ckeditor/ckeditor5-engine@^16.0.0": "patch:@ckeditor/ckeditor5-engine@npm:16.0.0#./patches/@ckeditor-ckeditor5-engine-npm-16.0.0-placeholder.patch" }, "scripts": { "lint": "tsc --noemit && stylelint 'packages/*/src/**/*.css' && yarn eslint 'packages/*/src/**/*.{js,jsx,ts,tsx}'", diff --git a/packages/neos-ui-ckeditor5-bindings/src/ckEditorApi.js b/packages/neos-ui-ckeditor5-bindings/src/ckEditorApi.js index 7579373ac1..9f8a78afe6 100644 --- a/packages/neos-ui-ckeditor5-bindings/src/ckEditorApi.js +++ b/packages/neos-ui-ckeditor5-bindings/src/ckEditorApi.js @@ -2,6 +2,7 @@ import debounce from 'lodash.debounce'; import DecoupledEditor from '@ckeditor/ckeditor5-editor-decoupled/src/decouplededitor'; import {actions} from '@neos-project/neos-ui-redux-store'; import {cleanupContentBeforeCommit} from './cleanupContentBeforeCommit' +// FIXME import from @ckeditor/ckeditor5-engine/theme/placeholder.css instead! (Needs build setup configuration) import './placeholder.vanilla-css'; let currentEditor = null; diff --git a/packages/neos-ui-ckeditor5-bindings/src/placeholder.vanilla-css b/packages/neos-ui-ckeditor5-bindings/src/placeholder.vanilla-css index 7249952164..ba96571daf 100644 --- a/packages/neos-ui-ckeditor5-bindings/src/placeholder.vanilla-css +++ b/packages/neos-ui-ckeditor5-bindings/src/placeholder.vanilla-css @@ -1,8 +1,17 @@ -.ck.ck-placeholder:before, .ck .ck-placeholder:before { - content: attr(data-placeholder); +.ck.ck-placeholder:after, .ck .ck-placeholder { + display: inline-flex; +} - /* See ckeditor/ckeditor5#469. */ - pointer-events: none; +.ck .ck-placeholder br[data-cke-filler="true"] { + display: none; +} +.ck.ck-placeholder:after, .ck .ck-placeholder:after { + content: attr(data-placeholder); + pointer-events: none; color: #999; } + +.ck.ck-read-only .ck-placeholder:after { + display: none; +} diff --git a/packages/neos-ui-editors/src/Library/LinkInput.js b/packages/neos-ui-editors/src/Library/LinkInput.js index af590598d6..18d5c2a58a 100644 --- a/packages/neos-ui-editors/src/Library/LinkInput.js +++ b/packages/neos-ui-editors/src/Library/LinkInput.js @@ -149,6 +149,12 @@ export default class LinkInput extends PureComponent { } handleSearchTermChange = searchTerm => { + // trim leading whitespace as it can cause issues + // with the further processing + if (typeof searchTerm === 'string') { + searchTerm = searchTerm.trimStart(); + } + this.setState({searchTerm}); if (isUriOrInternalLink(searchTerm)) { @@ -269,9 +275,16 @@ export default class LinkInput extends PureComponent { } handleManualSetLink = () => { - this.props.onLinkChange(this.state.searchTerm); + let {searchTerm} = this.state; + // trim tailing whitespace as it can cause issues + if (typeof searchTerm === 'string') { + searchTerm = searchTerm.trim(); + this.setState({searchTerm}); + } + + this.props.onLinkChange(searchTerm); this.setState({ - isEditMode: !this.state.searchTerm + isEditMode: !searchTerm }); } diff --git a/patches/@ckeditor-ckeditor5-engine-npm-16.0.0-placeholder.patch b/patches/@ckeditor-ckeditor5-engine-npm-16.0.0-placeholder.patch new file mode 100644 index 0000000000..ccf8c1751b --- /dev/null +++ b/patches/@ckeditor-ckeditor5-engine-npm-16.0.0-placeholder.patch @@ -0,0 +1,22 @@ +diff --git a/src/view/placeholder.js b/src/view/placeholder.js +index ec83640d4f7d12d8278c921a3c641917543ca859..09e96933b392f38d079ac3126ead49690e408228 100755 +--- a/src/view/placeholder.js ++++ b/src/view/placeholder.js +@@ -155,16 +155,7 @@ export function needsPlaceholder( element ) { + const isEmptyish = !Array.from( element.getChildren() ) + .some( element => !element.is( 'uiElement' ) ); + +- // If the element is empty and the document is blurred. +- if ( !doc.isFocused && isEmptyish ) { +- return true; +- } +- +- const viewSelection = doc.selection; +- const selectionAnchor = viewSelection.anchor; +- +- // If document is focused and the element is empty but the selection is not anchored inside it. +- if ( isEmptyish && selectionAnchor && selectionAnchor.parent !== element ) { ++ if ( isEmptyish ) { + return true; + } + diff --git a/yarn.lock b/yarn.lock index 2028aa23e8..6ab6af382a 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2037,7 +2037,7 @@ __metadata: languageName: node linkType: hard -"@ckeditor/ckeditor5-engine@npm:^16.0.0": +"@ckeditor/ckeditor5-engine@npm:16.0.0": version: 16.0.0 resolution: "@ckeditor/ckeditor5-engine@npm:16.0.0" dependencies: @@ -2047,6 +2047,16 @@ __metadata: languageName: node linkType: hard +"@ckeditor/ckeditor5-engine@patch:@ckeditor/ckeditor5-engine@npm:16.0.0#./patches/@ckeditor-ckeditor5-engine-npm-16.0.0-placeholder.patch::locator=root-workspace-0b6124%40workspace%3A.": + version: 16.0.0 + resolution: "@ckeditor/ckeditor5-engine@patch:@ckeditor/ckeditor5-engine@npm%3A16.0.0#./patches/@ckeditor-ckeditor5-engine-npm-16.0.0-placeholder.patch::version=16.0.0&hash=582e01&locator=root-workspace-0b6124%40workspace%3A." + dependencies: + "@ckeditor/ckeditor5-utils": ^16.0.0 + lodash-es: ^4.17.10 + checksum: 0ca241d6d28da9d7104c943d9ff2bf88591eb2e2726189029c3c43f8d59f726a10decc2aeb21db95a7e0242a4fc37fc480270869ca5a2f7d5db381107a385e38 + languageName: node + linkType: hard + "@ckeditor/ckeditor5-enter@npm:^16.0.0": version: 16.0.0 resolution: "@ckeditor/ckeditor5-enter@npm:16.0.0"