xref: /plugin/include/syntax/header.php (revision 62633254176a82afb33aa3b920e4a7015d3251fc)
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