Lexer->addSpecialPattern(LinkUtility::LINK_PATTERN, $mode, PluginUtility::getModeForComponent($this->getPluginComponent())); } /** * The handler for an internal link * based on `internallink` in {@link Doku_Handler} * The handler call the good renderer in {@link Doku_Renderer_xhtml} with * the parameters (ie for instance internallink) * @param string $match * @param int $state * @param int $pos * @param Doku_Handler $handler * @return array|bool */ function handle($match, $state, $pos, Doku_Handler $handler) { /** * Because we use the specialPattern, there is only one state ie DOKU_LEXER_SPECIAL */ $attributes = LinkUtility::getAttributes($match); $tag = new Tag(self::TAG, $attributes, $state, $handler->calls); $parent = $tag->getParent(); $parentName = ""; if ($parent != null) { $parentName = $parent->getName(); } return array( PluginUtility::ATTRIBUTES => $attributes, PluginUtility::PARENT_TAG => $parentName ); } /** * Render the output * @param string $format * @param Doku_Renderer $renderer * @param array $data - what the function handle() return'ed * @return boolean - rendered correctly? (however, returned value is not used at the moment) * @see DokuWiki_Syntax_Plugin::render() * * */ function render($format, Doku_Renderer $renderer, $data) { // The data switch ($format) { case 'xhtml': /** @var Doku_Renderer_xhtml $renderer */ /** * Cache problem may occurs while releasing */ if (isset($data[PluginUtility::ATTRIBUTES])) { $attributes = $data[PluginUtility::ATTRIBUTES]; } else { $attributes = $data; } $ref = $attributes[LinkUtility::ATTRIBUTE_REF]; $name = $attributes[LinkUtility::ATTRIBUTE_NAME]; $type = $attributes[LinkUtility::ATTRIBUTE_TYPE]; $link = new LinkUtility($ref); if ($name != null) { $link->setName($name); } $link->setType($type); /** * Render the link */ $htmlLink = $link->render($renderer); /** * Extra styling for internal link */ $parentTag = $data[PluginUtility::PARENT_TAG]; switch ($parentTag) { case syntax_plugin_combo_button::TAG: if ($link->getType() == LinkUtility::TYPE_INTERNAL) { if ($link->getInternalPage()->existInFs()) { $htmlLink = LinkUtility::deleteDokuWikiClass($htmlLink); } } $htmlLink = LinkUtility::inheritColorFromParent($htmlLink); break; case syntax_plugin_combo_cite::TAG: case syntax_plugin_combo_listitem::TAG: case syntax_plugin_combo_preformatted::TAG: if ($link->getType() == LinkUtility::TYPE_INTERNAL) { if ($link->getInternalPage()->existInFs()) { $htmlLink = LinkUtility::deleteDokuWikiClass($htmlLink); } } break; case syntax_plugin_combo_dropdown::TAG: if ($link->getType() == LinkUtility::TYPE_INTERNAL) { if ($link->getInternalPage()->existInFs()) { $htmlLink = LinkUtility::deleteDokuWikiClass($htmlLink); } } $htmlLink = HtmlUtility::addAttributeValue($htmlLink, "class", "dropdown-item"); break; case syntax_plugin_combo_navbarcollapse::COMPONENT: $htmlLink = ''; break; case syntax_plugin_combo_navbargroup::COMPONENT: $htmlLink = ''; break; } /** * Add it to the rendering */ $renderer->doc .= $htmlLink; return true; break; case 'metadata': /** * Keep track of the backlinks ie meta['relation']['references'] * @var Doku_Renderer_metadata $renderer */ if (isset($data[PluginUtility::ATTRIBUTES])) { $attributes = $data[PluginUtility::ATTRIBUTES]; } else { $attributes = $data; } $ref = $attributes[LinkUtility::ATTRIBUTE_REF]; $link = new LinkUtility($ref); $name = $attributes[LinkUtility::ATTRIBUTE_NAME]; if ($name != null) { $link->setName($name); } $link->handleMetadata($renderer); return true; break; case Analytics::RENDERER_FORMAT: /** * * @var renderer_plugin_combo_analytics $renderer */ $attributes = $data[PluginUtility::ATTRIBUTES]; $ref = $attributes[LinkUtility::ATTRIBUTE_REF]; $link = new LinkUtility($ref); $link->processLinkStats($renderer->stats); break; } // unsupported $mode return false; } }