xref: /plugin/include/syntax/header.php (revision 45c6515cdda30db7aff2b975732c89c56425ca23)
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
2871ec1101SGina Haeussge    function handle($match, $state, $pos, &$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     */
386f0ad9d7SMichael Klier    function render($mode, &$renderer, $data) {
39*45c6515cSMichael Hamann        global $conf;
40*45c6515cSMichael Hamann
41*45c6515cSMichael Hamann        list($headline, $lvl, $pos, $page, $sect, $flags) = $data;
42d8ec72fbSMichael Hamann        $hid = $renderer->_headerToLink($headline, true);
4371ec1101SGina Haeussge        if ($mode == 'xhtml') {
446f0ad9d7SMichael Klier            $renderer->toc_additem($hid, $headline, $lvl);
45d53221c4SMichael Klier            $url = ($sect) ? wl($page) . '#' . $sect : wl($page);
463a39ce39SMichael Klier            $renderer->doc .= DOKU_LF.'<h' . $lvl;
47*45c6515cSMichael Hamann            $classes = array();
483a39ce39SMichael Klier            if($flags['taglogos']) {
493a39ce39SMichael Klier                $tag = $this->_get_firsttag($page);
503a39ce39SMichael Klier                if($tag) {
51*45c6515cSMichael Hamann                    $classes[] = 'include_firsttag__' . $tag;
523a39ce39SMichael Klier                }
533a39ce39SMichael Klier            }
54*45c6515cSMichael Hamann            // the include header instruction is always at the beginning of the first section edit inside the include
55*45c6515cSMichael Hamann            // wrap so there is no need to close a previous section edit.
56*45c6515cSMichael Hamann            if ($lvl <= $conf['maxseclevel']) {
57*45c6515cSMichael Hamann                $classes[] = $renderer->startSectionEdit($pos, 'section', $headline);
58*45c6515cSMichael Hamann            }
59*45c6515cSMichael Hamann            if ($classes) {
60*45c6515cSMichael Hamann                $renderer->doc .= ' class="'. implode(' ', $classes) . '"';
61*45c6515cSMichael 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;
676f0ad9d7SMichael Klier        } elseif($mode == 'metadata') {
686f0ad9d7SMichael Klier            $renderer->toc_additem($hid, $headline, $lvl);
6971ec1101SGina Haeussge            return true;
7071ec1101SGina Haeussge        }
7171ec1101SGina Haeussge        return false;
7271ec1101SGina Haeussge    }
733a39ce39SMichael Klier
743a39ce39SMichael Klier    /**
753a39ce39SMichael Klier     * Optionally add a CSS class for the first tag
763a39ce39SMichael Klier     *
773a39ce39SMichael Klier     * @author Michael Klier <chi@chimeric.de>
783a39ce39SMichael Klier     */
793a39ce39SMichael Klier    function _get_firsttag($page) {
803a39ce39SMichael Klier        if(plugin_isdisabled('tag') || (!$taghelper =& plugin_load('helper', 'tag'))) {
813a39ce39SMichael Klier            return false;
823a39ce39SMichael Klier        }
833a39ce39SMichael Klier        $subject = p_get_metadata($page, 'subject');
843a39ce39SMichael Klier        if (is_array($subject)) {
853a39ce39SMichael Klier            $tag = $subject[0];
863a39ce39SMichael Klier        } else {
873a39ce39SMichael Klier            list($tag, $rest) = explode(' ', $subject, 2);
883a39ce39SMichael Klier        }
893a39ce39SMichael Klier        if($tag) {
903a39ce39SMichael Klier            return $tag;
913a39ce39SMichael Klier        } else {
923a39ce39SMichael Klier            return false;
933a39ce39SMichael Klier        }
943a39ce39SMichael Klier    }
9571ec1101SGina Haeussge}
962524d407SMichael Hamann// vim:ts=4:sw=4:et:
97