Setting user TSconfig¶
It is recommended to always define custom user TSconfig in a project-specific sitepackage extension. This way the user TSconfig settings can be kept under version control.
Importing the user TSconfig into a backend user or group¶
-
Open the record of the user or group. Go to Options > TSconfig.
-
Enter the following TSconfig to import a configuration file from your sitepackage:
@import 'EXT:my_sitepackage/Configuration/TsConfig/User/my_editor.tsconfig'
Copied!
This will make all settings in the file available to the user. The file itself can be kept under version control together with your sitepackage.
TSconfig defined at user level overrides TSconfig defined at group level.
If a user is a member of several groups, the TSconfig from each group is loaded. The order in which the groups are added to the user in field General > Group is used.
The TSconfig from latter groups overrides the TSconfig from earlier groups if both define the same property.
Setting default user TSconfig¶
New in version 13.0
Starting with TYPO3 v13.0 user TSconfig in a file named
Configuration/user.tsconfig
in an extension is automatically loaded
during build time.
User TSconfig is designed to be individual for users or groups of users. However, good defaults can be defined and overridden by group or user-specific TSconfig.
Default user TSconfig should be stored within an extension, usually a
sitepackage extension. The content of the file
Configuration/user.tsconfig
within an extension is automatically loaded
during build time.
It is possible to load other user TSconfig files with the import syntax within this file:
@import 'EXT:my_sitepackage/Configuration/TsConfig/User/default.tsconfig'
The PSR-14 event BeforeLoadedUserTsConfigEvent is available to add global static user TSconfig before anything else is loaded.
User TSconfig, compatible with TYPO3 v12 and v13¶
In TYPO3 v12 installations the content of Configuration/user.tsconfig
is
not loaded automatically. You can achieve compatibility with both TYPO3 v12 and
v13 by importing the content of this file with the API function
ExtensionManagementUtility::addUserTSConfig
:
<?php
declare(strict_types=1);
use TYPO3\CMS\Core\Information\Typo3Version;
use TYPO3\CMS\Core\Utility\ExtensionManagementUtility;
use TYPO3\CMS\Core\Utility\GeneralUtility;
defined('TYPO3') or die();
$versionInformation = GeneralUtility::makeInstance(Typo3Version::class);
// Only include user.tsconfig if TYPO3 version is below 13 so that it is not imported twice.
if ($versionInformation->getMajorVersion() < 13) {
ExtensionManagementUtility::addUserTSConfig(
'@import "EXT:my_sitepackage/Configuration/user.tsconfig"'
);
}
Deprecated since version 13.0
The method \TYPO3\CMS\Core\Utility\ExtensionManagementUtility::addUserTSConfig()
has been marked as deprecated in TYPO3 v13 and will be removed with TYPO3
v14.
Verify the final configuration¶
The full user TSconfig of the currently logged-in backend user can be viewed using the System > Configuration backend module and choosing the action $GLOBALS['BE_USER']->getTSConfig() (User TSconfig). However this module can only be accessed by admins.
The Configuration module is available with installed lowlevel system extension.
Override and modify values¶
Properties, which are set in the TSconfig field of a group, are valid for all users of that group.
Values set in one group can be overridden and modified in the same or another group. If a user is a member of multiple groups, the TSconfig settings are evaluated in the order in which the groups are included in the user account: When editing the backend user, the selected groups are evaluated from top to bottom.
Example:
-
Add in user TSconfig
page.RTE.default.showButtons = bold
Copied! - You get the value "bold".
-
Add later in user TSconfig
page.RTE.default.showButtons := addToList(italic)
Copied! - You get the value "bold,italic".
Finally, you can override or modify the settings from groups that your user is a member of in the user TSconfig field of that specific user.
Example:
Let's say the user is a member of a usergroup with this configuration:
TCAdefaults.tt_content {
hidden = 1
header = Hello!
}
Then we set the following values in the TSconfig field of the specific user.
page.TCAdefaults.tt_content.header = 234
options.clearCache.all = 1
This would override the default value of the header ("234") and add the clear cache option. The default value of the hidden field is not changed and simply inherited directly from the group.
Overriding page TSconfig in user TSconfig¶
All properties from page TSconfig can be overridden in user TSconfig by
prepending the property name with page.
.
When a page TSconfig property is set in user TSconfig that way, regardless of whether it is in the TSconfig field of a group or a user, it overrides the value of the according page TSconfig property.
To illustrate this feature let's say new pages and copied pages are not hidden by default:
TCAdefaults.pages.hidden = 0
TCEMAIN.table.pages.disableHideAtCopy = 1
If we activate the following configuration in the user TSconfig of a certain backend
user group, new and copied pages will be hidden for that group. The user TSconfig to
be used is the same, but prefixed with page.
// Override the settings from the page TSconfig for the editors usergroup
page {
TCAdefaults.pages.hidden = 1
TCEMAIN.table.pages.disableHideAtCopy = 0
}
Attention
It is not possible to reference the value of a property from page TSconfig and to modify this value in user TSconfig! If you set a property in user TSconfig, which already had been set in page TSconfig, then the value from page TSconfig will be overridden.
The result of the example below is not the value "bold,italic", but the value "italic".
# Enable the "bold" button in Page TSconfig (!)
RTE.default.showButtons = bold
# Try to additionally add the "italic" button in User TSconfig (!)
page.RTE.default.showButtons := addToList(italic)