簡體   English   中英

新聞鏈接處理程序(TYPO 8)和類別的詳細信息頁面

[英]news linkhandler (TYPO 8) and detailpage from category

在 TYPO3 中使用新的鏈接處理程序時,如下面的鏈接:

https://usetypo3.com/linkhandler.html

詳情頁面只有一個參數:

config.recordLinks.tx_news {
    typolink {
        parameter = {$myConstants.newsDetailPid}
}
}

ich如何更改鏈接處理程序(掛鈎等)以便從新聞類別(sys類別)獲取詳細信息頁面?

使用以下代碼:

config.recordLinks.tx_news {
    typolink {
        parameter.stdWrap.cObject = CONTENT 
        parameter.stdWrap.cObject { 
            table = sys_category 
            select { 
                pidInList = 100
                # pid of category records 
                max = 1
                selectFields = sys_category.single_pid AS detailPid 
                join = sys_category_record_mm ON sys_category_record_mm.uid_local = sys_category.uid 
                where = sys_category_record_mm.uid_foreign = { field: uid } 
                where.insertData = 1 
                andWhere.stdWrap.intVal = 1 
                andWhere.stdWrap.stripHtml = 1 
            }     
            renderObj = TEXT 
            renderObj.field = detailPid 
            renderObj.wrap = | 
        }   
        additionalParams.data = field:uid
        additionalParams.wrap = &tx_news_pi1[news]=|
        useCacheHash = 1
    }   
}   

https://www.clickstorm.de/blog/linkhandler-typo3/

您可以在這里找到鏈接處理程序集成的文檔: https ://docs.typo3.org/typo3cms/extensions/core/8.7/Changelog/8.6/Feature-79626-IntegrateRecordLinkHandler.html

在那里您可以看到可以為處理指定自己的類。 據我所知,沒有提供任何掛鈎。

下一個即將發布的 ext:news 版本可以實現這一點,詳情請參閱此更改

通過使用以下 TypoScript

config.recordLinks.tx_news {
    typolink {
        # Detail page
        parameter.cObject = USER
        parameter.cObject {
            userFunc = GeorgRinger\News\Service\LinkHandlerTargetPageService->process
            news.data = field:uid
            # Page used if no detail page is set in the category
            fallback = 123
        }
        additionalParams.data = field:uid
        additionalParams.wrap = &tx_news_pi1[controller]=News&tx_news_pi1[action]=detail&tx_news_pi1[news]=|
    }
}

和相應的用戶功能

<?php

declare(strict_types=1);

namespace GeorgRinger\News\Service;

use TYPO3\CMS\Core\Database\ConnectionPool;
use TYPO3\CMS\Core\Utility\GeneralUtility;
use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer;

/**
 * This file is part of the "news" Extension for TYPO3 CMS.
 *
 * For the full copyright and license information, please read the
 * LICENSE.txt file that was distributed with this source code.
 */
class LinkHandlerTargetPageService
{

    /** @var ContentObjectRenderer */
    public $cObj;

    public function process(string $content = '', array $configuration = []): int
    {
        $fallbackPageId = (int)($configuration['fallback'] ?? 0);

        $newsId = (int)$this->cObj->stdWrapValue('news', $configuration, null);
        if ($newsId === 0) {
            return $fallbackPageId;
        }

        $singlePid = $this->getSinglePidFromCategory($newsId);
        return $singlePid ?: $fallbackPageId;
    }

    /**
     * Obtains a pid for the single view from the category.
     *
     * @param int $newsId
     * @return int
     */
    protected function getSinglePidFromCategory(int $newsId): int
    {
        $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)
            ->getQueryBuilderForTable('sys_category');
        $categoryRecord = $queryBuilder
            ->select('title', 'single_pid')
            ->from('sys_category')
            ->leftJoin(
                'sys_category',
                'sys_category_record_mm',
                'sys_category_record_mm',
                $queryBuilder->expr()->eq('sys_category_record_mm.uid_local', $queryBuilder->quoteIdentifier('sys_category.uid'))
            )
            ->where(
                $queryBuilder->expr()->eq('sys_category_record_mm.tablenames', $queryBuilder->createNamedParameter('tx_news_domain_model_news', \PDO::PARAM_STR)),
                $queryBuilder->expr()->gt('sys_category.single_pid', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT)),
                $queryBuilder->expr()->eq('sys_category_record_mm.uid_foreign', $queryBuilder->createNamedParameter($newsId, \PDO::PARAM_INT))
            )
            ->orderBy('sys_category_record_mm.sorting')
            ->setMaxResults(1)
            ->execute()->fetch();
        return (int)$categoryRecord['single_pid'];
    }

}

當然,您可以將 PHP Class 復制到您的站點 package 並采用 TS 中的命名空間,並使其在您的安裝中運行

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM