Я пишу расширение extbase в TYPO3 7.6 для организации команды.Ключ расширения - это отряд.Каждая команда принадлежит тренеру, у которого есть запись в таблице fe_users.Так что в моей модели команды есть отношение к таблице fe_users.Я начал с компоновщика расширений и затем скорректировал свою модель, следуя инструкциям на этих сайтах: https://www.typo3.net/forum/thematik/zeige/thema/126982/ и TYPO3 Extbase fe_user в собственной модели В бэкэнде связь работает нормально, но в веб-интерфейсеЯ не вижу тренера в списке команд.Чего не хватает?
Мой код выглядит следующим образом.
ext_tables.sql:
CREATE TABLE tx_squad_domain_model_team (
...
trainer int(11) unsigned DEFAULT '0',
...
)
TCA.php:
'trainer' => [
'label' => 'Trainer',
'config' => [
'type' => 'select',
'renderType' => 'selectSingle',
'foreign_table' => 'fe_users',
'minitems' => 0,
'maxitems' => 1,
],
]
ext_typoscript_setup.txt
config.tx_extbase {
persistence {
classes {
TYPO3\CMS\Extbase\Domain\Model\FrontendUser {
subclasses {
Tx_Squad_FrontendUser = VENDOR\Squad\Domain\Model\FrontendUser
}
}
VENDOR\Squad\Domain\Model\FrontendUser {
mapping {
tableName = fe_users
recordType = Tx_Squad_FrontendUser
}
}
}
}
}
Model Team.php
class Team extends \TYPO3\CMS\Extbase\DomainObject\AbstractEntity
{
/**
* trainer
*
* @var \TYPO3\CMS\Extbase\Domain\Model\FrontendUser
*/
protected $trainer;
/**
* Returns the trainer
*
* @return \TYPO3\CMS\Extbase\Domain\Model\FrontendUser $trainer
*/
public function getTrainer()
{
return $this->trainer;
}
/**
* Sets the trainer
*
* @param \TYPO3\CMS\Extbase\Domain\Model\FrontendUser $trainer
* @return void
*/
public function setTrainer(\TYPO3\CMS\Extbase\Domain\Model\FrontendUser $trainer)
{
$this->trainer = $trainer;
}
}
Шаблоны / Team / List.html
...
<f:for each="{teams}" as="team">
<f:debug>{team}</f:debug>
<tr>
<td>{team.trainer}</td>
<td><f:link.action action="show" arguments="{team: team}"> {team.name}</f:link.action></td>
<td><f:link.action action="show" arguments="{team: team}"> {team.ccemail}</f:link.action></td>
<td><f:link.action action="edit" arguments="{team: team}">Edit</f:link.action></td>
<td><f:link.action action="delete" arguments="{team: team}">Delete</f:link.action></td>
</tr>
</f:for>
...