
Problem/Motivation
Gutenberg is currently written primarily with Node entities in mind.
I think the module should be flexible enough to work with most (content) entity types e.g. Taxonomy terms.
As part of this work, I think we should move away from storing all the configurations in gutenberg.settings.yml
and moving towards storing them as third_party_settings
on the entity type and working from there.
This also makes it easier to map the configuration to a schema rather than dynamically setting them.
https://www.drupal.org/project/config_inspector may be used to inspect the configuration schema.
Proposed resolution
- Add update hook deprecating
gutenberg.settings
, and moving active Gutenberg settings into the appropriate node type third party settings. - Introduce a new dedicated entity type settings page to configure Gutenberg.
- Introduce a new Gutenberg setting which allows admins to specify the text field to use for Gutenberg rather than defaulting to the first text field.
- Support YAML and JSON on the Field Mapping template definitions - since YAML is a superset of JSON, we can safely use
Yaml::decode
rather thanjson_decode
, YAML is way more human friendly to use and fits well with the Drupal ecosystem. - Introduce some kind of API to specify which entity types should support Gutenberg (thoughts welcome on this).
Remaining tasks
Implement as part of the #3107797: Dynamic render blocks support (API rework using WordPress block parser rather than regex) work.
User interface changes
- Move the Gutenberg settings into its own page/tab (Similar to Field Settings)
- Support YAML for the Field Mapping template textarea
API changes
N/A
Data model changes
- The
gutenberg.settings
configuration will be moved into the relevantnode.type.$entity_type
third_party_settings
.
Comment | File | Size | Author |
---|---|---|---|
#39 | Regular- ontent-type.PNG | 61.58 KB | freddy rodriguez |
#39 | Block-config-dev-branch.PNG | 44.98 KB | freddy rodriguez |
#31 | content block.PNG | 46.51 KB | balajidharma |
#20 | 3163200-19.fix-non-gutenberg-entity-issue.patch | 694 bytes | jrb |
Issue fork gutenberg-3163200
Show commands
Start within a Git clone of the project using the version control instructions.
Or, if you do not have SSH keys set up on git.drupalcode.org:
Comments
Comment #2
marcofernandes CreditAttribution: marcofernandes at Frontkom commentedHonestly, on all projects I've worked that used Gutenberg, I never found a necessity to use the editor on other entity types besides node. But, I guess, there could be some edge use cases.
I agree with the proposed resolution, just regarding:
It should always default to the first text field and give an option to change it.
Comment #3
veleiro CreditAttribution: veleiro as a volunteer commentedThe use case is compatibility with https://www.drupal.org/project/eck
Comment #4
hanoiiWhy doing this on a per entity setting rather than on a per field configuration, if anything is needed?
Isn't a text input format enough?
Comment #6
jrbAs far as use cases go, a basic one would be using Gutenberg on Taxonomy Term pages.
For us, we're hoping to use this on Group entities.
Comment #7
jrbI've pushed some code to the 3163200-make-gutenberg-entity fork. These changes include:
1. Adding
hook_gutenberg_entity_info()
to allow definition of entities that support Gutenberg.2. Adding a service used to indicate if Gutenberg is enabled for a given entity/route (see #3142648: Extract $gutenberg_enabled logic into separate functions).
3. Changing Gutenberg to save to Third-party settings for the entity.
With these changes, it does continue to work correctly for Nodes.
It will also support implementing the hook like this to enable Gutenberg for Taxonomy terms:
With this, you can then enable Gutenberg for individual Taxonomy Vocabularies. That's where the work ends...
To get it actually working to allow using Gutenberg on the term edit page, there needs to be some work done on the form/templates. I've got some separate code (not pushed) that attempts to do this, but it doesn't quite work yet. Gutenberg does take over the edit term page, but it gets stuck on "Loading..." because (I think) the form isn't rendered on the page correctly.
This work also does not:
1. Create a separate page for the Gutenberg settings (it uses the same Details element).
2. Update the schema as needed.
Comment #8
jrbI've pushed code to the 3163200-make-gutenberg-entity fork to add support for using Gutenberg on other entities, specifically taxonomy terms. I've changed the main Gutenberg module to be more-or-less entity-agnostic, but the support for terms is in a separate gutenberg_taxonomy_term module (included).
You should be able add support for different types of entities by implementing three functions in a custom module:
hook_gutenberg_entity_info()
to specify the entity.hook_form_FORM_ID_alter()
to rearrange form fields so the right ones are moved to the sidebar.hook_theme_suggestions_page_alter()
to set the theme suggestion to use the Gutenberg edit page template.See the gutenberg_taxonomy_term code for an example.
I haven't done a whole lot of testing yet, but it seems to work.
Comment #9
codebymikey CreditAttribution: codebymikey at Zodiac Media commentedHi @jrb,
Sorry for the lack of update on this issue. I really appreciate the work done so far, in particular the addition of tests (which the project is extremely lacking at the moment!).
I've essentially already implemented about 80% of this feature back in August, then stopped working on it to focus on other work.
It automatically integrates with most content entities (including node, taxonomy and eck) in an agnostic way (each module won't need explicit registration), making use of the
hook_entity_type_alter
hook, addingsetLinkTemplate
andsetFormClass
properties to the relevant entity types taking a similar approach to howcontent_translation
does.Most site installations won't need to explicitly register an entity type assuming it's a valid content entity type (and supports bundles).
I've implemented everything referenced in the original description with the exception of providing a stable way to hijack the editor template of the relevant entity types without messing up special third party behaviours like content_moderation etc. which also implement the
hook_form_node_form_alter
and might have a higher module hook weight than Gutenberg (e.g. if they're installed after Gutenberg).The idea is to do away with the "More settings" section and provide a way for users to switch between the "native" Drupal editor and the Gutenberg editor through a click of a button.
I'll try and set some time aside to mess around and finally land the feature, and if I'm unable to due to time constraints, I can push my work up for someone to try and finish off.
Hi @hanoii,
That was my initial thought as well, but then on further thought with regards to how Gutenberg works and how much configuration and special handling is required, keeping it on the entity level made the most sense usability-wise.
Some justification for being on the entity level rather than field:
Comment #10
jrb@codebymikey
Well, if you've got working code, I'd love to see it. If it's close, maybe we can help finish it off.
Comment #12
codebymikey CreditAttribution: codebymikey at Zodiac Media commentedPushed the latest code up, and needs further review and testing before it's released into Gutenberg 2.x.
Feedback is more than welcome on some of the TODOs and FIXMEs.
Comment #13
drupalina CreditAttribution: drupalina commentedI was bummed out to find that Gutenberg doesn't work for taxonomy pages. I really-really need this for my new 9.x site. My taxonomy pages are fully fledged write-ups full of unformatted info on the topic. And I've seen many drupal sites using such architecture in the past. So far I'm doing it by writing HTML code manually (not always easy to keep track of div opening and closing). A Gutenberg working on taxonomy pages would be a huge saver.
For those of us not code-savy, has this already been added to 2.x-dev?
Many thanks in advance.
Comment #14
jrb@codebymikey
I'm looking at the branch you pushed, but I don't see the ability to enable Gutenberg for any entities, Nodes included. How do you enable this? I saw
entity-support.md
, but that seems to refer to new, custom modules that you could createconfig/schema/custom_entity.schema.yml
files for.What am I missing?
Comment #15
jrb@codebymikey
Your latest push to the 8.x-2.x-3163200-entity-agnostic branch seems to work pretty well. Thanks!
@drupalina
This work isn't in the dev branch, but you can use it in your project with a Composer command like this:
Or, you can download the code here:
https://git.drupalcode.org/project/gutenberg/-/tree/8.x-2.x-3163200-enti...
If you can help test this out, we can work on getting it merged into dev.
Comment #16
drupalina CreditAttribution: drupalina commented@jrb (I don't know how to use composer) I'd be happy to test it out on my taxonomy pages, but when I click your link and click the download icon and choose tar.gz, it redirects me to Gutenberg project page on D.o - and nothing happens - nothing gets downloaded.
Is there another way that I can download that version of Gutenberg 2.x ??? Can you attach a .tar.gz or .rar or .zip file in your comment?
Many thanks!
Comment #17
jrb@drupalina
Yeah, I guess you can't download the code from there.
I've attached a .zip file of the that branch of module as of 26 March 2021 (the latest). Please try it out and add comments here with any issues (or to say it's working great!).
Comment #18
drupalina CreditAttribution: drupalina commented@jrb Thanks for attaching the zip file.
Here's my initial test report:
On my 9.x localhost site I've replaced the gutenberg module directory with the gutenberg branch attached inside this zip. Gutenberg module stopped showing among installed modules in "Available updates". So I went into modules page to enable it, it gave me a white screen with "The website encountered an unexpected error. Please try again later.". The front page of the site still worked, but the white screen with error returned every time you try to edit an Article where Gutenberg experience is enabled. In taxonomy pages settings, I did not notice any new settings.
So I removed the guttenberg directory, ran update.php, and then put this "agnostic" branch of guttenberg folder into modules again and ran update.php again. And this time it worked. The Gutenberg settings appeared in Taxonomy pages, and the old taxonomy pages with bootstrap columns were converted into html pages. This means that I have to re-do all the taxonomy pages (oh well, it's ok).
I still have to test how well the conversion of old HTML works, and whether it degrades gracefully (say if after few years one has written loads of content and one wants to switch away from gutenberg - Will the old gutenberg pages retain their basic html structure, or will we have to re-write hundreads/thousands of pages again? that's important from SEO perspective...), but for now, my initial conclusion is that although the installation/upgrade is a little "flaky" (maybe I forgot to do update.php in my first attempt), overall it seems to work on my 9.x site for taxonomy pages (I only tried the default "body" field).
I should say, this is a much better UX for creating content-rich pages, than writing boostrap HTML manually, or using Layout Builder, Paragraphs, or the super-bulky Elementor. So I think this branch should definitely be included in main 2.x branch.
I'm going to test some more over the coming days (especially in the context or bootstrap integration) and if things are as good as now, I'm going to include this branch in my production site, where most of SEO-ed content lives in Taxonomy pages.
Comment #19
drupalina CreditAttribution: drupalina commentedComment #20
jrbOn this branch when editing/creating a user, we're getting this fatal error:
I've attached a patch to fix this. This may also fix the white screen issue @drupalina mentions above when editing a node.
P.S. I'd have done this on the feature branch, but I'm not sure how to do that given that this work is on a separate branch and not the feature branch from this issue.
Comment #21
jrbThere was a similar issue on the menu item create/edit page, too. I'd guess that this may be an issue on many different entity types.
The patch in #20 fixes the issue with menu items and should fix it everywhere.
Comment #22
drupalina CreditAttribution: drupalina commentedI've been using this branch on a production site for a 2+ months now. It is especially useful for making content rich taxonomy pages. All works fine, and as expected. The only downer is that it's impossible to keep track of Gutenberg in the "Available Updates" page. Would it be possible to merge this branch into the new mainstream 2.x branch?
Comment #23
szeidler CreditAttribution: szeidler at Ramsalt Lab commentedThanks for all the reviews. Although it might not be on top of the list, we maintainers have an eye on this issue. I think this is a really good addition, since there no reasons to limit us to nodes only. I'm planning to do a proper review soon.
Out of curiosity: have you used the branch for a new installation or did you moved from already existing Gutenberg driven page to that branch?
Comment #24
drupalina CreditAttribution: drupalina commented@szeidler Thanks! as said in #18, on WAMP localhost I had standard Gutenberg installed (with Drupal 9.x), which I later replaced with the zip attachment in #17. After using it for couple of days and seeing that it fully addresses my needs of easily making rich-content taxonomy pages, I moved the entire installation of the website into live production. And that's where it has been since.
I did also manually apply the patch in #20 (basically, just replaced one for another) on the live site.
The only drawback is that now Gutenberg doesn't show up in "Available Updates", so it's impossible to track and update.
Comment #25
thorandre CreditAttribution: thorandre at Frontkom commentedSeems like there is a lot of interest to these features and the fact that several sites are already using this in production is a good indication that this go into a near future release.
Adding both v2.1 and v2.2 tags as we don't know yet which one at the moment.
We'll test this branch on multiple current Gutenberg sites/installations to check how this works with existing setups and do at least 2x of code review here since it's a large change with lots of potential conflicts.
Comment #26
szeidler CreditAttribution: szeidler at Ramsalt Lab commentedI was starting to review the feature and the initial impression is quite good. Thanks for the incredible job here. I'm testing the branch with a fresh installation and based on an existing Drupal 8 and Drupal 9 installation.
But here some remarks.
The code is currently not mergeable
The simple reason is just the time the feature has been under development and the lack of attention for reviews for some time. But since there has been a couple of commits coming in in the last months/weeks we need to rebase the branch and resolve the merge errors.
In addition we need to increase the update hook numbers. We also need to decide if we care about the ones already using that branch/patch. Because their updates might fail when we're bumping the update hook numbers. So either we add additional checks for the config modification, to skip if it's already in the new data structure or we need to communicate it here.
There is a problem with entity types without bundles
I found an issue with content entity forms, that don't have bundles, such as the user form.
We need to support/not break bundleless entity types.
Enable field mapping
I like the option and avoiding processing overhead. But where is the overhead actually being created? Couldn't we even on-the-fly really early leave, when we don't see any field_mapping defined? If we agree to keep it like that: Would we need an additional option? Couldn't we just parse the template and check if there is a field mapping or not (and store the boolean field_mapping value if really necessary)?
Comment #27
thorandre CreditAttribution: thorandre at Frontkom commentedRemoving this from the v2.1 release as discussed in the Gutenberg status meeting today. Will hopefully be ready for the v2.2 release
Comment #30
codebymikey CreditAttribution: codebymikey at Zodiac Media commentedThe preview of the entity agnostic implementation is available here:
The login credentials are u:admin p:admin.
The code needs review and the implementation needs testing.
The minimal install is probably not necessary, but a nice way to see what Gutenberg looks like on a different non-standard admin theme.
Comment #31
balajidharmaThank you codebymikey! for above demo URLs

Gutenberg option missing for content blocks.
This feature is requested in #3123818: Enable Gutenberg editor on core Content Blocks
Comment #32
avpadernoComment #33
marcofernandes CreditAttribution: marcofernandes at Frontkom commentedI'm tagging this to v2.3 release.
Already did some tests and it seems to be working good. I've also missed the inclusion of the Gutenberg settings on Block content type form. I tried to add it to gutenberg.schema.yml file but nothing happened. I confirmed that Block content type class supports the ThirdPartySettingsInterface class. Still, perhaps I'm missing something.
As szeidler said, I'm also not sure if we need the field mapping processing option but I'm ok by leaving it ;)
Really great work @codebymikey and all contributors on this feature.
Comment #34
codebymikey CreditAttribution: codebymikey at Zodiac Media commentedThe nullpointer exception has been addressed for unsupported entity types.
The overhead comes from having to parse the entire HTML every time the entity is saved, I think it's unnecesary if the content type won't make use of it.
I personally don't use the field mapping feature, but I can see the template being useful, so it could be potentially inefficient to recursively parse the template trying to find the fieldMapping reference, when the content type inherently doesn't want to support it.
Based on the current implementation, it's also possible that the template might not be the source of truth for the field mapping since
mappingFields
might be implemented in a custom block (the code doesn't do any checks to ensure that thefield_mapping
actually matches what was defined in the template).@balajidharma and @marcofernandes
I was primarily focused on first class citizen bundle-able Entities like Nodes, Taxonomy Terms, ECK etc (which have dedicated canonicals/edit forms in terms of integration) - I guess block content integration would be nice, but hasn't been implemented/tested yet or wasn't deemed necessary at the time of implementation (we'd have to add a lot more config schema definitions), based on the way Gutenberg works on the WordPress side of things.
The
gutenberg.schema.yml
file is mainly useful for Drupal config to normalize and translate the config data. It's not necessary for integration.The entity integration logic is contained in the
gutenberg_entity_type_alter
function.Comment #35
marcofernandes CreditAttribution: marcofernandes at Frontkom commentedThanks @codebymikey, all clear by me. Done some more tests and it seems good to me. Moving this to RTBC.
Btw, we'll try to do more tests on client projects when in dev branch. After that we'll decide if release 2.3 will have a beta 😉
Comment #36
marcofernandes CreditAttribution: marcofernandes at Frontkom commentedActually some changes went into dev branch and now we need to rebase again.
Comment #38
codebymikey CreditAttribution: codebymikey at Zodiac Media commentedRemerged with latest dev.
Comment #39
freddy rodriguezHello codeymikey and marcofernandes. How can I help with the review? I installed the latest dev version, created a new custom block type with a long text field and chose the gutenberg display in that field, but there is no option in the block for enable the gutenberg experience as appears in the regular node content types. - Core D9.3.9
Comment #40
alfthecat CreditAttribution: alfthecat commentedRE: #39 the patch doesn't support blocks, but I think it would be fantastic if that could be added to the scope. Having Gutenberg in blocks is a powerful page building asset.
Comment #41
eiriksmThis MR needs to be rebased or merged up to date
Comment #42
thorandre CreditAttribution: thorandre at Frontkom commentedThis is a duplicate of #3445655: Entity type agnostic where we'll continue to work on this.
Comment #43
nelo_drup CreditAttribution: nelo_drup commentedThis is something that I have wanted to use in the block types. Is this patch compatible with the current version of the module?