任务:在类别菜单中显示每个类别中项目的计数,例如
我尝试按需求计算,但确实没有工作
<?php
namespace HIT\huskytheme\ViewHelpers\News;
class CountCategoriesViewHelper extends \TYPO3\CMS\Fluid\Core\ViewHelper\AbstractViewHelper {
/**
* @var \GeorgRinger\News\Domain\Repository\NewsRepository
* @inject
*/
protected $newsRepository = null;
/**
*
* @param string $category
* @return string
*/
public function render($category) {
$demand = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('GeorgRinger\\News\\Domain\\Model\\Dto\\NewsDemand');
//$demand->setDateField('datetime');
$demand->setStoragePage(10, true);
// for example by id = 2
$demand->setCategories(2);
$demand->setCategoryConjunction('and');
$demand->setIncludeSubCategories('1');
//$demand->setArchiveRestriction($settings['archiveRestriction']);
$statistics = $this->newsRepository->countByCategories($demand);
\TYPO3\CMS\Core\Utility\DebugUtility::debug($statistics);
return $this->newsRepository->countByCategories($demand);
}
}
但是只要0,如果打电话
{namespace s=HIT\huskytheme\ViewHelpers}
{s:news.countCategories(category: 2)}
答案 0 :(得分:1)
没有方法countByCategories
实现类似需求对象的方法。请直接使用DB。
答案 1 :(得分:1)
根据类别的数量以及在非缓存页面上显示此菜单的需要,我建议不要直接在控制器中查看帮助方式,而是查询DB(如Georg建议的那样)。只需连接您的插槽即可发出GeorgRinger\News\Controller\CategoryController
:listAction
信号。您将获得所有类别(在参数categories
中)并可以启动
SELECT COUNT(*) FROM sys_category_record_mm … GROUP BY uid_local
一次性获取所有计数。然后只需将新密钥添加到您返回的数组中,并在该名称下的模板中使用它。
答案 2 :(得分:1)
Actualy我找到了获取类别新闻数量的方法。 Thx Georg Ringer和undko
我的ViewHelper
<?php
namespace HIT\huskytheme\ViewHelpers\News;
class CountCategoriesViewHelper extends \TYPO3\CMS\Fluid\Core\ViewHelper\AbstractViewHelper {
/**
* @var \GeorgRinger\News\Domain\Repository\NewsRepository
* @inject
*/
protected $newsRepository = null;
/**
*
* @param \GeorgRinger\News\Domain\Model\Category $category
* @return string
*/
public function render($category) {
/* @var $demand \GeorgRinger\News\Domain\Model\Dto\NewsDemand */
$demand = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance(\GeorgRinger\News\Domain\Model\Dto\NewsDemand::class);
$demand->setCategories(array($category));
$demand->setCategoryConjunction('and');
$demand->setIncludeSubCategories(false);
return count($this->newsRepository->findDemanded($demand));
}
}
在我的tx_news模板/类别/ List.html
中<!-- load my ViewHelper -->
{namespace s=HIT\huskytheme\ViewHelpers}
这里加上计数
...
<f:link.page title="{category.item.title}" class="current-item" pageUid="{settings.listPid}"
additionalParams="{tx_news_pi1:{overwriteDemand:{categories: category.item.uid}}}">{category.item.title}
<span class="postnum">({s:news.countCategories(category: category.item)})</span>
</f:link.page>
...