xref: /plugin/include/syntax/header.php (revision 4aa23dc032350bb192c5996b0a65b04b948100b8)
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 Haeussgeif (!defined('DOKU_INC'))
1371ec1101SGina Haeussge    define('DOKU_INC', realpath(dirname(__FILE__) . '/../../') . '/');
1471ec1101SGina Haeussgeif (!defined('DOKU_PLUGIN'))
1571ec1101SGina Haeussge    define('DOKU_PLUGIN', DOKU_INC . 'lib/plugins/');
1671ec1101SGina Haeussgerequire_once (DOKU_PLUGIN . 'syntax.php');
1771ec1101SGina Haeussge
1871ec1101SGina Haeussgeclass syntax_plugin_include_header extends DokuWiki_Syntax_Plugin {
1971ec1101SGina Haeussge
2071ec1101SGina Haeussge    function getType() {
2171ec1101SGina Haeussge        return 'formatting';
2271ec1101SGina Haeussge    }
2371ec1101SGina Haeussge
2471ec1101SGina Haeussge    function getSort() {
2571ec1101SGina Haeussge        return 50;
2671ec1101SGina Haeussge    }
2771ec1101SGina Haeussge
28*4aa23dc0SGerrit Uitslag    function handle($match, $state, $pos, Doku_Handler $handler) {
2971ec1101SGina Haeussge        // this is a syntax plugin that doesn't offer any syntax, so there's nothing to handle by the parser
3071ec1101SGina Haeussge    }
3171ec1101SGina Haeussge
3271ec1101SGina Haeussge    /**
3371ec1101SGina Haeussge     * Renders a permalink header.
3471ec1101SGina Haeussge     *
3571ec1101SGina Haeussge     * Code heavily copied from the header renderer from inc/parser/xhtml.php, just
3671ec1101SGina Haeussge     * added an href parameter to the anchor tag linking to the wikilink.
3771ec1101SGina Haeussge     */
38*4aa23dc0SGerrit Uitslag    function render($mode, Doku_Renderer $renderer, $data) {
3945c6515cSMichael Hamann        global $conf;
4045c6515cSMichael Hamann
4145c6515cSMichael Hamann        list($headline, $lvl, $pos, $page, $sect, $flags) = $data;
428d636b31SMichael Hamann
4371ec1101SGina Haeussge        if ($mode == 'xhtml') {
448d636b31SMichael Hamann            /** @var Doku_Renderer_xhtml $renderer */
458d636b31SMichael Hamann            $hid = $renderer->_headerToLink($headline, true);
466f0ad9d7SMichael Klier            $renderer->toc_additem($hid, $headline, $lvl);
47d53221c4SMichael Klier            $url = ($sect) ? wl($page) . '#' . $sect : wl($page);
483a39ce39SMichael Klier            $renderer->doc .= DOKU_LF.'<h' . $lvl;
4945c6515cSMichael Hamann            $classes = array();
503a39ce39SMichael Klier            if($flags['taglogos']) {
513a39ce39SMichael Klier                $tag = $this->_get_firsttag($page);
523a39ce39SMichael Klier                if($tag) {
5345c6515cSMichael Hamann                    $classes[] = 'include_firsttag__' . $tag;
543a39ce39SMichael Klier                }
553a39ce39SMichael Klier            }
5645c6515cSMichael Hamann            // the include header instruction is always at the beginning of the first section edit inside the include
5745c6515cSMichael Hamann            // wrap so there is no need to close a previous section edit.
5845c6515cSMichael Hamann            if ($lvl <= $conf['maxseclevel']) {
5945c6515cSMichael Hamann                $classes[] = $renderer->startSectionEdit($pos, 'section', $headline);
6045c6515cSMichael Hamann            }
6145c6515cSMichael Hamann            if ($classes) {
6245c6515cSMichael Hamann                $renderer->doc .= ' class="'. implode(' ', $classes) . '"';
6345c6515cSMichael Hamann            }
643a39ce39SMichael Klier            $headline = $renderer->_xmlEntities($headline);
6548f69f8eSMichael Hamann            $renderer->doc .= ' id="'.$hid.'"><a href="' . $url . '" title="' . $headline . '">';
663a39ce39SMichael Klier            $renderer->doc .= $headline;
676f0ad9d7SMichael Klier            $renderer->doc .= '</a></h' . $lvl . '>' . DOKU_LF;
686f0ad9d7SMichael Klier            return true;
698d636b31SMichael Hamann        } else {
708d636b31SMichael Hamann            $renderer->header($headline, $lvl, $pos);
7171ec1101SGina Haeussge        }
7271ec1101SGina Haeussge        return false;
7371ec1101SGina Haeussge    }
743a39ce39SMichael Klier
753a39ce39SMichael Klier    /**
763a39ce39SMichael Klier     * Optionally add a CSS class for the first tag
773a39ce39SMichael Klier     *
783a39ce39SMichael Klier     * @author Michael Klier <chi@chimeric.de>
793a39ce39SMichael Klier     */
803a39ce39SMichael Klier    function _get_firsttag($page) {
813a39ce39SMichael Klier        if(plugin_isdisabled('tag') || (!$taghelper =& plugin_load('helper', 'tag'))) {
823a39ce39SMichael Klier            return false;
833a39ce39SMichael Klier        }
843a39ce39SMichael Klier        $subject = p_get_metadata($page, 'subject');
853a39ce39SMichael Klier        if (is_array($subject)) {
863a39ce39SMichael Klier            $tag = $subject[0];
873a39ce39SMichael Klier        } else {
883a39ce39SMichael Klier            list($tag, $rest) = explode(' ', $subject, 2);
893a39ce39SMichael Klier        }
903a39ce39SMichael Klier        if($tag) {
913a39ce39SMichael Klier            return $tag;
923a39ce39SMichael Klier        } else {
933a39ce39SMichael Klier            return false;
943a39ce39SMichael Klier        }
953a39ce39SMichael Klier    }
9671ec1101SGina Haeussge}
972524d407SMichael Hamann// vim:ts=4:sw=4:et:
98