In this tuto, I'll show you how to add custom data on configuration menu entity using the ThirdPartySettingsInterface .
By default configuration menu entity fields is like this:
In this article we are going to look at how to use the ThirdPartySettingsInterface to add some extra fields to existing configuration menu entity. For example, if you ever need to store some config together with a node type or a taxonomy vocabulary, there is a great way to do so using this interface.
Today we are going to see an example of this and add an extra fields to the menu definition and store the value in this way.
There are a number of steps involved in this process. First, we need to alter the form with which the entity configuration data is added and saved. In the case of the menu entity there are two forms (one for adding and one for editing) so we need to alter them both.
I added a new #entity_builder
to the form which will be triggered when the form is submitted.
Create mymodule.module file:
The getThirdPartySetting()
method on the entity object is provided by the ThirdPartySettingsInterface
which all configuration entities have by default if they extend from the ConfigEntityBase
class. with this method we simply retrieve a value that is stored as third party settings.
We need also to add our configuration schema so that it becomes translatable. Inside the /config/schema/mymodule.schema.yml
file of our module we need to add this:
config/schema/mymodule.schema.yml
With this schema definition we are basically appending to the schema of the system.menu
config menu entity by specifying some metadata about the third party settings our module provides. For more information on config schemas be sure to check out the docs on Drupal.org.
After adding our custom fields to existing config menu entity the result is like this: