繁体   English   中英

如何将新闻中的 showPrevNext 限制为类别?

[英]How to limit showPrevNext in news to categories?

在带有 tx_news 8.3.0 的 TYPO3 CMS 9.5.18 LTS 中,我们使用以下扩展 Typoscript:

plugin.tx_news.settings{
  # what is allowed to overwrite with TS
  overrideFlexformSettingsIfEmpty := addToList(categories)
  overrideFlexformSettingsIfEmpty := addToList(categoryConjunction)
  # ids of categories
  categories = 3
  # category conjunction mode
  categoryConjunction = or
}

我想知道为什么我必须添加类别来覆盖FlexformSettingsIfEmpty 才能得到下面的结果。 这篇文章更多的是关于如何实现上一个/下一个链接(settings.detail.showPrevNext)确实尊重类别定义。

我们的客户有 3 个新闻类别。 如果我将 go 转到具有一个类别限制的单个页面(对于详细信息和列表页面),我仍然可以 go “转发”到完全不同类别中的更新新闻。 然而,列表页面仅显示该选定类别的新闻。

<f:if condition="{paginated.prev}">
    <n:link newsItem="{paginated.prev}" settings="{settings}" class="ts-prev">
        {paginated.prev.title}
    </n:link>
</f:if>

从来不是这样吗? 我是否必须添加一些 Typoscript 或更改 Fluid? 原始代码使用此设置变量作为包含类别限制的参数。

好的,我查看了 GeorgRinger\News\ViewHelpers\SimplePrevNextViewHelper 并且当前选择的类别没有任何限制。

所以这就是我所做的:

  1. 向 viewhelper 注册一个新的可选参数categories
  2. categories="{settings.categories}"添加到 Detail.html 中的 simplePrevNext 标记
  3. getNeighbours function 中的主查询添加“额外位置”
  4. 添加附加内容的内容(我首先在 getNeighbours function 中做了)

额外的地方:

if( is_array($newsOfCategory) && count($newsOfCategory) > 0 ){
    $extraWhere[] = $queryBuilder->expr()->in('uid', $queryBuilder->createNamedParameter($newsOfCategory, Connection::PARAM_INT_ARRAY));
}

附加内容 where:

if( is_string($categories) && preg_match('/^[0-9]+(,[0-9]+)*$/',$categories) ){
    $categories = explode(',', $categories);
    $tmpCon = GeneralUtility::makeInstance(ConnectionPool::class)->getConnectionForTable('sys_category_record_mm');
    $tmpQB = $tmpCon->createQueryBuilder();
    $rows = $tmpQB
        ->select('uid_foreign')
        ->from('sys_category_record_mm')
        ->where(
            $tmpQB->expr()->in('uid_local', $tmpQB->createNamedParameter($categories, Connection::PARAM_INT_ARRAY))
        )
        ->andWhere(
            $tmpQB->expr()->like('tablenames', $tmpQB->createNamedParameter('tx_news_domain_model_news'))
        )
        ->execute()->fetchAll();
    if( is_array($rows) && count($rows) > 0 ){
        foreach($rows as $row){
            $newsOfCategory[] = $row['uid_foreign'];
        }
    }
}

将来可能有人可以使用它,或者将其集成到存储库中。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM