Add custom fields
Follow this chapter to learn how to add new fields or actions.
It is important to know how this concept is implemented. If a class should be extended, EXT:news will generate a new file containing the original class of the extension itself and all other classes which should extended it.
Take a look at the following 2 working examples:
- Add relation to a FE user: https://github.com/cyberhouse/t3ext-newsauthor
- Add an image gallery to a news record: https://github.com/cyberhouse/t3ext-news_gallery
Attention
This generator works only with the news version 3.2.0 or higher.
Warning
The drawbacks are easy to identify:
- Don't use any use statements as those are currently ignored!
- It is not possible to override an actual method or property!
The files are saved by using the Caching Framework in the directory typo3temp/
.
1) Add a new field in the backend
To add new fields, use either the extension extension_builder or create the extension from scratch.
The extension key used in this examples is eventnews
.
Create the fields
3 files are basically all what you need:
ext_emconf.php
The file ext_
holds all basic information about the extension like the title, description and version number.
<?php
$EM_CONF[$_EXTKEY] = [
'title' => 'news events',
'description' => 'Events for news',
'category' => 'plugin',
'author' => 'Georg Ringer',
'author_email' => '',
'state' => 'alpha',
'uploadfolder' => false,
'createDirs' => '',
'clearCacheOnLoad' => true,
'version' => '1.0.0',
'constraints' => [
'depends' => [
'typo3' => '7.6.13-8.7.99',
'news' => '6.2.0-6.9.99',
],
'conflicts' => [],
'suggests' => [],
],
];
SQL definition
Create the file ext_
in the root of the extension directory with the following content:
# Table structure for table 'tx_news_domain_model_news '
#
CREATE TABLE tx_news_domain_model_news (
location_simple varchar(255) DEFAULT '' NOT NULL
);
TCA definition
The TCA defines which tables and fields are available in the backend and how those are rendered (e.g. as input field, textarea, select field, ...).
In this example, the table tx_
will be extended by a simple input field.
Therefore, create the file Configuration/
.
<?php
defined('TYPO3') or die();
$fields = [
'location_simple' => [
'exclude' => 1,
'label' => 'My location',
'config' => [
'type' => 'input',
'size' => 15
],
]
];
\TYPO3\CMS\Core\Utility\ExtensionManagementUtility::addTCAcolumns('tx_news_domain_model_news', $fields);
\TYPO3\CMS\Core\Utility\ExtensionManagementUtility::addToAllTCAtypes('tx_news_domain_model_news', 'location_simple');
Install the extension
Now you should be able to install the extension and if you open a news record, you should see the new field in the last tab.
2) Register the class
Until now, EXT:news won't use the new field because it doesn't know about it. To change that, you need to register your new model.
Registration
Create the file ext_
in the root of the extension:
<?php
defined('TYPO3') or die();
$GLOBALS['TYPO3_CONF_VARS']['EXT']['news']['classes']['Domain/Model/News']['eventnews'] = 'eventnews';
Domain/
is the namespace to the class which should be extended and eventnews
is the extension key.
Custom class
As the class Domain/
should be extended, create a file at the same path in the own extension which is
path/
:
<?php
namespace GeorgRinger\Eventnews\Domain\Model;
class News extends \GeorgRinger\News\Domain\Model\News
{
protected string $locationSimple;
public function getLocationSimple(): string
{
return $this->locationSimple;
}
public function setLocationSimple(string $locationSimple)
{
$this->locationSimple = $locationSimple;
}
}
3) Exclude the class from dependecy injection
As the class you define will be added to a new generated class, the class needs to be excluded from dependency injection in Configuration/Services.yaml:
services:
_defaults:
autowire: true
autoconfigure: true
public: false
GeorgRinger\Eventnews\:
resource: '../Classes/*'
exclude: '../Classes/Domain/Model/*'
Hint
If you are using the extension extension_
, this class might have been created for you already.
Important
If you reference other objects, you must define the full namespace at the location and don't use namespace imports (with "use")!
Clear system cache
Now it is time to clear the system cache, either via the dropdown in the backend or in the module Admin Tools.