Feature: #99220 - Add event to modify search results
See forge#99220
Description
A new PSR-14 event \TYPO3\
is added to allow extension developers to take control over search result items
rendered in the backend search.
The event has a public method called get
, returning the
\TYPO3\
instance of the search
result item.
Impact
Search result items may be modified within a custom event listener, e.g. to add custom actions.
Example
<?php
namespace MyVendor\MyExtension\Search\EventListener;
use TYPO3\CMS\Backend\Routing\UriBuilder;
use TYPO3\CMS\Backend\Search\Event\ModifyResultItemInLiveSearchEvent;
use TYPO3\CMS\Backend\Search\LiveSearch\DatabaseRecordProvider;
use TYPO3\CMS\Backend\Search\LiveSearch\ResultItemAction;
use TYPO3\CMS\Core\Imaging\Icon;
use TYPO3\CMS\Core\Imaging\IconFactory;
use TYPO3\CMS\Core\Localization\LanguageService;
use TYPO3\CMS\Core\Localization\LanguageServiceFactory;
final class AddLiveSearchResultActionsListener
{
protected LanguageService $languageService;
public function __construct(
protected readonly IconFactory $iconFactory,
protected readonly LanguageServiceFactory $languageServiceFactory,
protected readonly UriBuilder $uriBuilder
) {
$this->languageService = $this->languageServiceFactory->createFromUserPreferences($GLOBALS['BE_USER']);
}
public function __invoke(ModifyResultItemInLiveSearchEvent $event): void
{
$resultItem = $event->getResultItem();
if ($resultItem->getProviderClassName() !== DatabaseRecordProvider::class) {
return;
}
if (($resultItem->getExtraData()['table'] ?? null) === 'tt_content') {
/**
* WARNING: THIS EXAMPLE OMITS ANY ACCESS CHECK FOR SIMPLICITY REASONS.
* DO NOT USE AS-IS!
*/
$showHistoryAction = (new ResultItemAction('view_history'))
->setLabel($this->languageService->sL('LLL:EXT:core/Resources/Private/Language/locallang_mod_web_list.xlf:history'))
->setIcon($this->iconFactory->getIcon('actions-document-history-open', Icon::SIZE_SMALL))
->setUrl((string)$this->uriBuilder->buildUriFromRoute('record_history', [
'element' => $resultItem->getExtraData()['table'] . ':' . $resultItem->getExtraData()['uid']
]));
$resultItem->addAction($showHistoryAction);
}
}
}
Copied!
MyVendor\MyExtension\Search\EventListener\AddLiveSearchResultActionsListener:
tags:
- name: event.listener
identifier: 'site/add-live-search-result-actions-listener'
Copied!