.. include:: /Includes.rst.txt .. index:: LinkHandlers; CustomLinkHandlers .. _customlinkhandler: ================================= Implementing a custom LinkHandler ================================= It is possible to implement a custom LinkHandler if links are to be created and handled that cannot be handled by any of the Core LinkHandlers. The example below is part of the TYPO3 Documentation Team extension `examples `__. .. todo: Replace the source code here with the code from EXT:examples and adjust the texts https://github.com/TYPO3-Documentation/TYPO3CMS-Reference-CoreApi/issues/2298 Implementing the LinkHandler ============================ You can have a look at the existing LinkHandler in the system extension "backend", found at :file:`typo3/sysext/backend/Classes/LinkHandler`. .. versionchanged:: 12.0 Due to the integration of EXT:recordlist into EXT:backend the path has changed from :file:`typo3/sysext/recordlist/Classes/LinkHandler` to :file:`typo3/sysext/backend/Classes/LinkHandler`. For TYPO3 v12 the moved classes are available as an alias under the old namespace to allow extensions to be compatible with TYPO3 v11 and v12. However please note that all these extensions extend the :php:`AbstractLinkHandler`, which is marked as :php:`@internal` and subject to change without further notice. You should therefore implement the interface :php:`LinkHandlerInterface` in your custom LinkHandlers: .. code-block:: php :caption: EXT:some_extension/Classes/LinkHandler/GitHubLinkHandler.php linkBrowser = $linkBrowser; $this->iconFactory = GeneralUtility::makeInstance(IconFactory::class); $this->view = GeneralUtility::makeInstance(StandaloneView::class); $this->view->getRequest()->setControllerExtensionName('examples'); $this->view->setTemplateRootPaths([GeneralUtility::getFileAbsFileName('EXT:examples/Resources/Private/Templates/LinkBrowser')]); $this->configuration = $configuration; } /** * Checks if this is the handler for the given link * * Also stores information locally about currently linked issue * * @param array $linkParts Link parts as returned from TypoLinkCodecService * * @return bool */ public function canHandleLink(array $linkParts) { if (isset($linkParts['url']['github'])) { $this->linkParts = $linkParts; return true; } return false; } /** * Format the current link for HTML output * * @return string */ public function formatCurrentUrl(): string { return $this->linkParts['url']['github']; } /** * Render the link handler * * @param ServerRequestInterface $request * * @return string */ public function render(ServerRequestInterface $request): string { GeneralUtility::makeInstance(PageRenderer::class) ->loadRequireJsModule('TYPO3/CMS/Examples/GitHubLinkHandler'); $this->view->assign('project', $this->configuration['project']); $this->view->assign('action', $this->configuration['action']); $this->view->assign('github', !empty($this->linkParts) ? $this->linkParts['url']['github'] : ''); return $this->view->render('GitHub'); } /** * @return string[] Array of body-tag attributes */ public function getBodyTagAttributes(): array { return []; } /** * @return array */ public function getLinkAttributes() { return $this->linkAttributes; } /** * @param string[] $fieldDefinitions Array of link attribute field definitions * @return string[] */ public function modifyLinkAttributes(array $fieldDefinitions) { return $fieldDefinitions; } /** * We don't support updates since there is no difference to simply set the link again. * * @return bool */ public function isUpdateSupported() { return FALSE; } } The LinkHandler then has to be registered via page TSconfig: .. code-block:: typoscript :caption: EXT:some_extension/Configuration/page.tsconfig TCEMAIN.linkHandler { github { handler = T3docs\\Examples\\LinkHandler\\GitHubLinkHandler label = LLL:EXT:examples/Resources/Private/Language/locallang_browse_links.xlf:github displayAfter = url scanBefore = url configuration { project = TYPO3-Documentation/TYPO3CMS-Reference-CoreApi action = issues } } } And the JavaScript, depending on :ref:`requirejs`, has to be added in a file :file:`examples/Resources/Public/JavaScript/GitHubLinkHandler.js`: .. code-block:: javascript /** * Module: TYPO3/CMS/Examples/GitHubLinkHandler * Github issue link interaction */ define(['jquery', 'TYPO3/CMS/Recordlist/LinkBrowser'], function($, LinkBrowser) { 'use strict'; /** * * @type {{}} * @exports T3docs/Examples/GitHubLinkHandler */ var GitHubLinkHandler = {}; $(function() { $('#lgithubform').on('submit', function(event) { event.preventDefault(); var value = $(this).find('[name="lgithub"]').val(); if (value === 'github:') { return; } if (value.indexOf('github:') === 0) { value = value.substr(7); } LinkBrowser.finalizeFunction('github:' + value); }); }); return GitHubLinkHandler; }); This would create a link looking like this: .. code-block:: html Example Link Which could, for example, be interpreted by a custom protocol handler on a company computer's operating system.