- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
>14 months have passed since #11: it's now late 2023, tomorrow is December 1!
https://www.drupal.org/project/ckeditor โ will be unsupported soon.
Time to start exploring our options.
- First commit to issue fork.
- Status changed to Needs work
12 months ago 7:40am 26 January 2024 - ๐ณ๐ฟNew Zealand quietone
I was on the fence about deprecating or not but asked the other rms. Catch replied saying that in this it is ok to remove them. He pointed out that plugins are internal and these are a specific use case. Plus, since these will be in use for year or two, possibly three, it would be more disruptive to deprecate.
Based on that I started to remove files. I did remove some provider tests from SmartDefaultSettingsTest but there remains a lot of CkEditor4 strings in setup().
This will fails tests so settings to NW.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Very interesting, I sort of expected this to not happen ๐ Then again, sites can't go from Drupal 9 to 11 directly (i.e. no bypassing Drupal 10), so โฆ it makes sense to do this.
It triggers โฆ Feels ๐ to be removing this โ I spent a lot of time building this. And I built it for clean ejection when it was no longer needed, which is NOW, so it does feel kinda satisfying (cathartic?) to see how nicely this is removing ~1250 LoC (and more soon) ๐คฉ
MR reviewed โ I explained which other test cases (which you already alluded to, @quietone!) that are safe to remove can be identified ๐
- ๐ฌ๐งUnited Kingdom catch
Changing the issue title to indicate we'd only remove this in 11.x - this means sites that are still using ckeditor4 will be able to use the upgrade path on 10.x, which is going to be maintained until around 2026, years after ckeditor4's EOL.
The reason I think this would be more disruptive to deprecate than just remove outright in 11.x is because if we deprecate we either have to remove usages (which we wouldn't want to do in 10.x, there are still well over 100,000 Drupal 9.5 sites), or workaround the deprecation notices in tests etc., which is not really deprecating then. We offer 'best effort' bc and deprecations for internal code, and in this case the best we can do is none at all.
- ๐ฌ๐งUnited Kingdom longwave UK
+1 to no deprecations, but maintaining this throughout Drupal 10 and a clean removal in Drupal 11, given that sites already must go from 9 to 10 before they can go to 11.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Failing on PHPStan:
139 Parameter $stylesheets_message of method Drupal\ckeditor5\Plugin\Editor\CKEditor5::__construct() has invalid type Drupal\ckeditor5\CKEditor5StylesheetsMessage.
Simple fix fortunately: that is just no longer necessary :)
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
10.3 has been branched. Does that mean this can land now? It's unlikely the affected will change in
10.3
too, so it's also unlikely that this'll make MRs more difficult to land? - Status changed to Needs review
11 months ago 3:07pm 29 February 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Merged in upstream changes. Then finished what @quietone started: removed all traces of
CKEditor5StylesheetsMessage
. - Assigned to wim leers
- Status changed to Needs work
11 months ago 3:19pm 29 February 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
The test cases in
SmartDefaultSettingsTest
are now almost all stale/irrelevant: they're specifically testing an update from CKEditor 4, and that's no longer necessary.Because going forward,
SmartDefaultSettings
can and will only look at the HTML restrictions of the text format. Will tackle that next. - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
https://git.drupalcode.org/project/drupal/-/merge_requests/6329/diffs?co... got us down to 2 failing tests:
SmartDefaultSettingsTest
as predicted in #27, plus\Drupal\Tests\ckeditor5\FunctionalJavascript\CKEditor5AllowedTagsTest::testSwitchToVersion5()
.I just pushed a commit that should make the latter pass, the commit message explains how/why.
- Status changed to Needs review
11 months ago 1:16pm 1 March 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
I recommend reviewing the test coverage changes using
Only two <code>@todo
s are left. This is 98% ready.
- ๐บ๐ธUnited States smustgrave
So long ckeditor4!
Following to review later.
- Issue was unassigned.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
And now it will be green! ๐ Whew, this was quite a lot of work: to keep the good parts of
SmartDefaultSettings
that are still relevant now that CKEditor 4 is gone.Bumping to given the diffstat of
+367, โ1731
. - ๐บ๐ธUnited States smustgrave
Reran the javascript failing test multiple times but seems to consistently fail :(
- Assigned to wim leers
- Status changed to Needs work
11 months ago 6:22pm 1 March 2024 - Issue was unassigned.
- Status changed to Postponed
11 months ago 4:22pm 5 March 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Merged in latest
11.x
.The failure is reproducible locally:
TypeError: Cannot read properties of null (reading 'length') at Object._parseSetting (http://localhost/subdirectory/core/modules/filter/filter.filter_html.admin.js?v=11.0-dev:310:39) at http://localhost/subdirectory/core/modules/filter/filter.filter_html.admin.js?v=11.0-dev:95:30 at Array.forEach (<anonymous>) at Object.attach (http://localhost/subdirectory/core/modules/filter/filter.filter_html.admin.js?v=11.0-dev:90:9) at http://localhost/subdirectory/core/misc/drupal.js?v=11.0-dev:166:24 at Array.forEach (<anonymous>) at Drupal.attachBehaviors (http://localhost/subdirectory/core/misc/drupal.js?v=11.0-dev:162:34) at http://localhost/subdirectory/core/misc/drupal.init.js?v=11.0-dev:32:12 at HTMLDocument.listener
โฆ but it'd be solved automatically by ๐ Deprecate core/modules/editor/js/editor.admin.js JS APIs in Drupal 10, for removal in Drupal 11 Fixed .
- Assigned to wim leers
- Status changed to Active
10 months ago 9:29am 20 March 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
- Issue was unassigned.
- Status changed to Needs review
10 months ago 9:55am 20 March 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
All green! ๐ ๐ฅณ
90% of this MR is trivial.
The 10% that is non-trivial is in
SmartDefaultSettings
. For it to continue to work (to provide default settings based on HTML restrictions of a text format, which 99% of the time means based onfilter_html
configuration), a few additions were necessary.You might question the need for that. Why:
- It makes it easy for existing text formats to adopt CKEditor 5
- It minimizes the changes to
SmartDefaultSettingsTest
- ๐บ๐ธUnited States smustgrave
Removal seems good. But question should this code be moved to the ckeditor4 contrib module?
I can imagine there are some still on ckeditor4 and they may upgrade to D11 while still trying to get to ckeditor5.
- ๐ฌ๐งUnited Kingdom catch
I think it's entirely reasonable to require people to update to ckeditor5 on Drupal 10 before going to Drupal 11, they've got until 2026 to do that and still be supported.
- Status changed to RTBC
10 months ago 3:32pm 20 March 2024 - ๐บ๐ธUnited States smustgrave
Good point, forgot about the 2 year overlap
- ๐ฌ๐งUnited Kingdom catch
I read through everything again and there was a few things I thought 'should we be deprecating this in 10.x first' and then I thought we don't want to deprecate it in 10.x because we want people to use it there to get onto ckeditor5, and then I re-read the issue and found us discussing the same thing already including me months ago and all the other release managers.
Committed/pushed to 11.x, thanks!
- Status changed to Fixed
10 months ago 3:26pm 22 March 2024 Automatically closed - issue fixed for 2 weeks with no activity.
- ๐ฌ๐งUnited Kingdom catch
We've still got a couple of ckeditor4 editor config exports supporting various tests, which I think possibly might not be for actual ckeditor4 upgrade path testing at all, but in which case should probably be renamed. Opened ๐ Remove redudundat hook_ENTITY_TYPE_presave() and ViewsConfigUpdater methods Active for that and some other issues when I tried to remove ckeditor5's overall 9-10.3 upgrade path.