171ec1101SGina Haeussge<?php 271ec1101SGina Haeussge/** 371ec1101SGina Haeussge * Include plugin (permalink header component) 471ec1101SGina Haeussge * 571ec1101SGina Haeussge * Provides a header instruction which renders a permalink to the included page 671ec1101SGina Haeussge * 771ec1101SGina Haeussge * @license GPL 2 (http://www.gnu.org/licenses/gpl.html) 871ec1101SGina Haeussge * @author Gina Haeussge <osd@foosel.net> 971ec1101SGina Haeussge * @author Michael Klier <chi@chimeric.de> 1071ec1101SGina Haeussge */ 1171ec1101SGina Haeussge 1271ec1101SGina Haeussgeclass syntax_plugin_include_header extends DokuWiki_Syntax_Plugin { 1371ec1101SGina Haeussge 1471ec1101SGina Haeussge function getType() { 1571ec1101SGina Haeussge return 'formatting'; 1671ec1101SGina Haeussge } 1771ec1101SGina Haeussge 1871ec1101SGina Haeussge function getSort() { 1971ec1101SGina Haeussge return 50; 2071ec1101SGina Haeussge } 2171ec1101SGina Haeussge 224aa23dc0SGerrit Uitslag function handle($match, $state, $pos, Doku_Handler $handler) { 2371ec1101SGina Haeussge // this is a syntax plugin that doesn't offer any syntax, so there's nothing to handle by the parser 2471ec1101SGina Haeussge } 2571ec1101SGina Haeussge 2671ec1101SGina Haeussge /** 2771ec1101SGina Haeussge * Renders a permalink header. 2871ec1101SGina Haeussge * 2971ec1101SGina Haeussge * Code heavily copied from the header renderer from inc/parser/xhtml.php, just 3071ec1101SGina Haeussge * added an href parameter to the anchor tag linking to the wikilink. 3171ec1101SGina Haeussge */ 324aa23dc0SGerrit Uitslag function render($mode, Doku_Renderer $renderer, $data) { 3345c6515cSMichael Hamann global $conf; 3445c6515cSMichael Hamann 3545c6515cSMichael Hamann list($headline, $lvl, $pos, $page, $sect, $flags) = $data; 368d636b31SMichael Hamann 3771ec1101SGina Haeussge if ($mode == 'xhtml') { 388d636b31SMichael Hamann /** @var Doku_Renderer_xhtml $renderer */ 398d636b31SMichael Hamann $hid = $renderer->_headerToLink($headline, true); 406f0ad9d7SMichael Klier $renderer->toc_additem($hid, $headline, $lvl); 41d53221c4SMichael Klier $url = ($sect) ? wl($page) . '#' . $sect : wl($page); 423a39ce39SMichael Klier $renderer->doc .= DOKU_LF.'<h' . $lvl; 4345c6515cSMichael Hamann $classes = array(); 443a39ce39SMichael Klier if($flags['taglogos']) { 453a39ce39SMichael Klier $tag = $this->_get_firsttag($page); 463a39ce39SMichael Klier if($tag) { 4745c6515cSMichael Hamann $classes[] = 'include_firsttag__' . $tag; 483a39ce39SMichael Klier } 493a39ce39SMichael Klier } 5045c6515cSMichael Hamann // the include header instruction is always at the beginning of the first section edit inside the include 5145c6515cSMichael Hamann // wrap so there is no need to close a previous section edit. 5245c6515cSMichael Hamann if ($lvl <= $conf['maxseclevel']) { 539986c3adSMichael Hamann if (defined('SEC_EDIT_PATTERN')) { // for DokuWiki Greebo and more recent versions 549986c3adSMichael Hamann $classes[] = $renderer->startSectionEdit($pos, array('target' => 'section', 'name' => $headline, 'hid' => $hid)); 559986c3adSMichael Hamann } else { 5645c6515cSMichael Hamann $classes[] = $renderer->startSectionEdit($pos, 'section', $headline); 5745c6515cSMichael Hamann } 589986c3adSMichael Hamann } 5945c6515cSMichael Hamann if ($classes) { 6045c6515cSMichael Hamann $renderer->doc .= ' class="'. implode(' ', $classes) . '"'; 6145c6515cSMichael Hamann } 623a39ce39SMichael Klier $headline = $renderer->_xmlEntities($headline); 6348f69f8eSMichael Hamann $renderer->doc .= ' id="'.$hid.'"><a href="' . $url . '" title="' . $headline . '">'; 643a39ce39SMichael Klier $renderer->doc .= $headline; 656f0ad9d7SMichael Klier $renderer->doc .= '</a></h' . $lvl . '>' . DOKU_LF; 666f0ad9d7SMichael Klier return true; 678d636b31SMichael Hamann } else { 688d636b31SMichael Hamann $renderer->header($headline, $lvl, $pos); 6971ec1101SGina Haeussge } 7071ec1101SGina Haeussge return false; 7171ec1101SGina Haeussge } 723a39ce39SMichael Klier 733a39ce39SMichael Klier /** 743a39ce39SMichael Klier * Optionally add a CSS class for the first tag 753a39ce39SMichael Klier * 763a39ce39SMichael Klier * @author Michael Klier <chi@chimeric.de> 773a39ce39SMichael Klier */ 783a39ce39SMichael Klier function _get_firsttag($page) { 79*62633254SMichael Hamann if(plugin_isdisabled('tag') || (!plugin_load('helper', 'tag'))) { 803a39ce39SMichael Klier return false; 813a39ce39SMichael Klier } 823a39ce39SMichael Klier $subject = p_get_metadata($page, 'subject'); 833a39ce39SMichael Klier if (is_array($subject)) { 843a39ce39SMichael Klier $tag = $subject[0]; 853a39ce39SMichael Klier } else { 863a39ce39SMichael Klier list($tag, $rest) = explode(' ', $subject, 2); 873a39ce39SMichael Klier } 883a39ce39SMichael Klier if($tag) { 893a39ce39SMichael Klier return $tag; 903a39ce39SMichael Klier } else { 913a39ce39SMichael Klier return false; 923a39ce39SMichael Klier } 933a39ce39SMichael Klier } 9471ec1101SGina Haeussge} 952524d407SMichael Hamann// vim:ts=4:sw=4:et: 96