Configuration Reference¶
YAML Configuration Reference¶
When configuring the CKEditor using YAML, these are the property names that are currently used:
processing¶
Configuring transformations kicks in the RteHtmlParser API of TYPO3, to only allow certain HTML tags and attributes when saving the database or leaving the database to the RTE. However, defining transformations towards RTE is not really necessary anymore. Defining more strict processing options when storing content in the database also needs to be ensured that CKEditor allows this functionality too.
This configuration option was previously built within RTE.
and can
still be overridden via Page TSconfig. Everything defined via “processing”
is available in RTE.proc and triggers RteHtmlParser options.
editor¶
Editor contains all RTE-specific options. All CKEditor-specific options, which one could imagine are available under “config” property and handed over to CKEditor’s instance-specific config array.
All other sub-properties are usually handled via TYPO3 and then injected in the
CKEditor instance at runtime. This is useful for registering extra plugins, like
the TYPO3 core does with a custom typo3-
plugin, or adding
third-party plugins like handling images.
editor.config¶
- editor.config
-
Configuration options For a list of all options see https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editorconfig-EditorConfig.html
Note
Some configuration options from the official CKEditor 5 documentation do not apply to TYPO3, since they are related to specific plugins (for example: CKBox, CloudServices) which are not bundled in TYPO3's CKEditor build.
- editor.config.language
-
defines the editor’s UI language, and is dynamically calculated (if not set otherwise) by the backend users’ preference.
- editor.config.contentsLanguage
-
defines the language of the data, which is fetched from the sys_language information, but can be overridden by this option as well. For referencing files, TYPO3's internal "EXT:" syntax can be used, for using language labels, TYPO3's "LLL:" language functionality can be used.
- editor.config.contentsCss
-
defines the CSS file of the editor and the styles that can be applied.
Example:
editor.config.contentsCss: - "EXT:rte_ckeditor/Resources/Public/Css/contents.css"
Copied!This is the default, as defined in EXT:rte_ckeditor/Configuration/RTE/Editor/Base.yaml (GitHub).
Note
When adding custom styling and fonts, all CSS declarations need to be prefixed with
.ck-
. This scoping is applied by TYPO3 automatically to all custom CSS styles. Referenced CSS stylesheets need to be downloadable viacontent fetch
in order for the JavaScript-based prefixing to work.()
- editor.config.heading
-
Defines headings available in the heading dropdown.
Example:
heading: options: - { model: 'heading2', view: 'h2', title: 'Heading 2' }
Copied!
- editor.config.style
-
Defines styles available in the style dropdown.
Example:
style: definitions: - { name: "Lead", element: "p", classes: ['lead'] } - { name: "Multiple", element: "p", classes: ['first', 'second'] }
Copied!
- editor.config.importModules
-
Imports custom CKEditor plugins. See EXT:rte_ckeditor/Configuration/RTE/Editor/Plugins.yaml (GitHub) or How do I create a custom plugin? for examples.
Link Browser specific options¶
There are more configuration options that can be defined in the YAML file of an RTE preset related to the Link Browser, when managing hyperlinks inside the CKEditor.
Note that the Link Browser can also be displayed based on FormEngine TCA definitions. These use similar configuration, but from their TCA PHP configuration, and unrelated to the YAML definition.
The additional example file EXT:rte_ckeditor/Configuration/RTE/Editor/LinkBrowser.yaml (GitHub) lists all of the following options as an example.
These options are a bit fragmented, it is important to watch for the proper indentation as well the proper option relation.
Important
Please note that these options are set at the topmost level, and not nested inside
the editor
YAML structure.
A short overview:
allowed
- allowed list of additional attribute boxesOptions allowed
- list of allowed Link Types inside the RTETypes classes
- list of default CSS and link target values per Link TypeAnchor buttons
- Additional sub-configuration array for specific dropdownsbuttons.
- Global options for the Link Browserlink. options buttons.
- Configuration for thelink. rel Attribute rel
attribute blockbuttons.
- Configuration for thelink. query Parameters Selector query
(URI arguments) attribute blockParameter buttons.
- Configuration for thelink. target Selector target
attribute blockbuttons.
- Allowed additional CSS classes in thelink. properties. class. allowed Classes CSS
attribute blockbuttons.
- Default CSS class per Link Typelink. [Link Type]. properties. class. default classes
- Label definitions for CSS class names
allowedOptions¶
This string contains a comma separated list of additional attributes used in the Link Browser.
Available field lists can be found in EXT:backend/Classes/Controller/AbstractLinkBrowserController.php (GitHub),
method get
.
Note that the attributes target
, class
and rel
are displayed differently depending on
whether the Link Browser was opened for a TCA element, or a RTE element. See
EXT:rte_ckeditor/Classes/Controller/BrowseLinksController.php (GitHub) in method
get
.
Valid attributes keys are:
- target
-
If set, an input box for link target (for example "_blank") is available.
- title
-
If set, entering the link title is available.
- class
-
If set, allowing to enter a CSS class name for the link is available. This needs to match the CSS classes made available to the CKEDitor instance.
- params
-
If set, additional parameters are allowed to be set for a link.
- rel
-
If set, relations (
rel
attribute) for links can be set.
To set all of them, you can use:
allowedOptions: 'target,title,class,params,rel'
To remove all options you can use an empty string:
allowedOptions: ''
allowedTypes¶
This string contains a comma-separated list of all allowed Link Types for the Link Browser. These are currently:
page
url
file
folder
email
...
any custom Link Type
allowedTypes: 'page,url,file,folder,email,customType'
To remove all types you can use an empty string:
allowedTypes: ''
classesAnchor¶
This is a sub-array of default CSS classes and target attributes, per Link Type:
classesAnchor:
- { class: "customPageCssClass", type: "page", target: "" }
- { class: "customUrlCssClass", type: "url", target: "_blank" }
- { class: "customFileCssClass", type: "file", target: "_parent" }
- { class: "customFolderCssClass", type: "folder" }
- { class: "customTelephoneCssClass", type: "telephone" }
- { class: "customEmailCssClass", type: "email" }
Note that the available CSS class here must also be part of the
buttons.
definition.
buttons.link¶
This structure defines both global options as well as Link Type-specific options:
buttons.link.options.removeItems¶
Can be set to exclude certain Link Types:
buttons:
link:
options:
removeItems: 'telephone'
buttons.link.relAttribute.enabled¶
If the allowed
string list contains rel
for setting relation
attributes, this option must also be enabled:
buttons:
link:
relAttribute:
enabled: true
buttons.link.queryParametersSelector.enabled¶
If the allowed
string list contains params
for setting URI argument
attributes, this option must also be enabled:
buttons:
link:
queryParametersSelector:
enabled: true
buttons.link.targetSelector.disabled¶
If the allowed
string list contains target
, a dropdown is displayed by
default. If you want to hide it, you must set this option to true
:
buttons:
link:
targetSelector:
disabled: true
buttons.link.properties.class.required¶
A CSS class selection can be forced, so that it may not be empty:
buttons:
link:
properties:
class:
required: true
buttons.link.properties.class.allowedClasses¶
This is the most vital CSS class selection list, based on a comma-separated string naming all CSS classes that are allowed. Default CSS classes per Link Type can only be selected, if they are part of this list.
The names of the CSS classes can be adjusted via the classes
top-level configuration
hierarchy (see below)
buttons:
link:
properties:
class:
allowedClasses: 'globalCss1,globalCss1,CustomPageCssClass'
buttons.link.[linkType].properties.class.default¶
For each Link Type, a default CSS class can be defined, using the name of the Link Type as a key:
buttons:
link:
telephone:
class:
default: "customTelephoneCssClass"
email:
class:
default: "customEmailCssClass"
Note that the CSS class listed here must also be contained in
buttons.
.
classes.[CssClassName]¶
The list of CSS classes defined in buttons.
can set a custom label as well as a styling the select option. Note that styling
select options does not work in every browser, and is not suggested to use.
The name of the structure key must match the CSS class name, with a sub-structure
defining name
(the actual label) and value
(the possible CSS styling of the option
inside the dropdown):
classes:
globalCss1:
name: "A Label for globalCss1"
value: "color: red"
customEmailCssClass:
name: "An email-specific class for VIPs"
Page TSconfig¶
We recommend you to put all configurations for the preset in the YAML configuration. However, it is still possible to override these settings through the page TSconfig.
You can find a list of configuration properties in the Page TSconfig reference, chapter RTE.