1<?php
2/**
3* DokuWiki Plugin dirtylittlehelper (Syntax Component)
4*
5* @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html
6* @author  KalleAPunkt
7*/
8
9// must be run within Dokuwiki
10if (!defined('DOKU_INC')) {
11die();
12}
13
14class syntax_plugin_dirtylittlehelper_mermaid extends DokuWiki_Syntax_Plugin
15{
16        var $dlh_handle = '';
17
18        /**
19        * @return string Syntax mode type
20        */
21        public function getType()
22        {
23                return 'substition';
24        }
25
26        /**
27        * @return string Paragraph type
28        */
29        public function getPType()
30        {
31                return 'normal';
32        }
33
34        /**
35        * @return int Sort order - Low numbers go before high numbers
36        */
37        public function getSort()
38        {
39                return 150;
40        }
41
42        /**
43        * Connect lookup pattern to lexer.
44        *
45        * @param string $mode Parser mode
46        */
47        public function connectTo($mode)
48        {
49                $this->Lexer->addEntryPattern('\<dlh\.mm\>',$mode,'plugin_dirtylittlehelper_'.$this->getPluginComponent());
50        }
51
52        public function postConnect()
53        {
54                $this->Lexer->addExitPattern('\<\/dlh\.mm\>','plugin_dirtylittlehelper_'.$this->getPluginComponent());
55
56        }
57
58
59        /**
60        * Handle matches of the DLH syntax
61        *
62        * @param string       $match   The match of the syntax
63        * @param int          $state   The state of the handler
64        * @param int          $pos     The position in the document
65        * @param Doku_Handler $handler The handler
66        *
67        * @return array Data for the renderer
68        */
69        public function handle($match, $state, $pos, Doku_Handler $handler)
70        {
71
72                switch ($state) {
73
74                        case DOKU_LEXER_ENTER:
75                                if($match=='<dlh.mm>'){
76                                        return array($state, 'MERMAID',$match);
77                                }
78
79                        case DOKU_LEXER_UNMATCHED :
80								return array($state, 'UNMATCHED', $match);
81
82                        case DOKU_LEXER_EXIT :
83                                if($match=='</dlh.mm>'){
84                                        return array($state, '/MERMAID',$match);
85                                }
86                }
87        return false;
88
89        } //handle
90
91
92        /**
93        * Render xhtml output or metadata
94        *
95        * @param string        $mode     Renderer mode (supported modes: xhtml)
96        * @param Doku_Renderer $renderer The renderer
97        * @param array         $data     The data from the handler() function
98        *
99        * @return bool If rendering was successful.
100        */
101        public function render($mode, Doku_Renderer $renderer, $data)
102        {
103                if ($mode == 'xhtml') {
104
105                        if($data[1]=='MERMAID'){
106                                // securityLevel loose allows more advanced functionality such as subgraphs to run.
107                                // @todo: this should be an option in the interface.
108                                $renderer->doc .= '<div class="mermaid">';
109								return true;
110
111                        }elseif($data[1]=='/MERMAID'){
112                                $renderer->doc .= "</div>";
113								return true;
114
115
116                        }elseif($data[1]=='UNMATCHED'){
117                                $renderer->doc .= $data[2];
118								return true;
119                        }
120
121                        return false;
122
123
124                } //mode xhtml
125
126        return false;
127
128        } //function render
129
130
131} //class
132
133
134
135
136
137
138