我做什么: Typo脚本
lib.category = CONTENT
lib.category {
table=sys_category
wrap=|
select {
pidInList = root,0,1
recursive = 99
max=10
selectFields=sys_category.title,sys_category.uid
join = sys_category_record_mm on sys_category_record_mm.uid_local = sys_category.uid join sys_file_metadata on sys_file_metadata.uid = sys_category_record_mm.uid_foreign join sys_file_reference on sys_file_reference.uid_local = sys_file_metadata.file
where.field = fuid
where.wrap = sys_file_reference.uid=|
}
renderObj=COA
renderObj {
1=TEXT
1.field = uid
2=TEXT
2.field = title
}
}
在流体中我有:
<f:for each="{files}" as="file">
<p>
- {file.uid}<br />
- <f:cObject typoscriptObjectPath="lib.category" data="{fuid:file.uid}" />
</p>
</f:for>
在它打印的网页上:
3Black7Small
89
2Blue7Big
90
但是我认为Fluid中的一个对象更好,所以我可以使用f:for each等。但是我不知道如何返回它。
有人能帮助我吗?
答案 0 :(得分:1)
看起来这个任务非常棘手。 file
数组中的{files}
对象的类型为\TYPO3\CMS\Core\Resource\FileReference
,其中uid,title或description等属性是从\TYPO3\CMS\Core\Resource\File
类型的原始文件对象传递的。 FileReference
实际上是作为模型而不是文件实现的,因此您无法扩展它。
我看到的唯一另一种方法是创建一个viewhelper,它将使用本机sql查询获取类别,而CategoryRepository会自动将结果映射到Category模型。这样的事情:
<?php
namespace Vendor\Extension\ViewHelpers;
/**
*
* @version $Id$
* @copyright Dimitri Lavrenuek <lavrenuek.de>
* @license http://www.gnu.org/licenses/gpl.html GNU General Public License, version 3 or later
*/
class GetFileCategoriesViewHelper extends \TYPO3\CMS\Fluid\Core\ViewHelper\AbstractViewHelper {
/**
* @var \TYPO3\CMS\Extbase\Domain\Repository\CategoryRepository
* @inject
*/
protected $categoryRepository;
/**
* @param int $uid
* @return array
*/
public function render ($uid) {
$query = $this->categoryRepository->createQuery();
$sql = "SELECT sys_category.* FROM sys_category
INNER JOIN sys_category_record_mm ON sys_category_record_mm.uid_local = sys_category.uid AND sys_category_record_mm.fieldname = 'categories' AND sys_category_record_mm.tablenames = 'sys_file_metadata'
INNER JOIN sys_file_metadata ON sys_category_record_mm.uid_foreign = sys_file_metadata.uid
WHERE sys_file_metadata.file = '" . (int)$uid . "'
AND sys_category.deleted = 0
ORDER BY sys_category_record_mm.sorting_foreign ASC";
return $query->statement($sql)->execute();
}
}
我还没有测试过实际的代码,只测试了sql查询,但这应该可行。另外,我希望您知道如何在流体模板中包含viewhelpers,如果不是,我将提供一个示例。