/
syntax.php
81 lines (70 loc) · 2.09 KB
/
syntax.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
<?php
/**
* MELLEL Plugin: Exports to MELLEL
*
* @author Simon Bruechner
*/
// must be run within Dokuwiki
if(!defined('DOKU_INC')) die();
if(!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN',DOKU_INC.'lib/plugins/');
require_once(DOKU_PLUGIN.'syntax.php');
class syntax_plugin_mellelexport extends DokuWiki_Syntax_Plugin {
/**
* return some info
*/
function getInfo(){
return confToHash(dirname(__FILE__).'/plugin.info.txt');
}
/**
* What kind of syntax are we?
*/
function getType(){
return 'substition';
}
/**
* What about paragraphs?
*/
function getPType(){
return 'normal';
}
/**
* Where to sort in?
*/
function getSort(){
return 318; // Before image detection, which uses {{...}} and is 320
}
/**
* Connect pattern to lexer
*/
function connectTo($mode) {
$this->Lexer->addSpecialPattern('~~MELLEL~~', $mode, 'plugin_mellelexport');
}
/**
* Handle the match
*/
function handle($match, $state, $pos, Doku_Handler $handler){
// Export button
if ($match == '~~MELLEL~~') { return array(); }
}
/**
* Create output
*/
function render($format, Doku_Renderer $renderer, $data) {
global $ID, $REV;
if (!$data) { // Export button
if($format != 'xhtml') {
return false;
}
$renderer->doc .= '<a href="'.exportlink($ID, 'mellelexport', ($REV != '' ? 'rev='.$REV : '')).'?purge=1&dummy='.microtime(true).'" title="Export page to Redit Mellel format">';
$renderer->doc .= '<img src="'.DOKU_BASE.'lib/plugins/mellelexport/MellelDocument.png" align="right" alt="Export page to Redit Mellel format" width="48" height="48" />';
$renderer->doc .= '</a>';
return true;
} else { // Extended info
list($info_type, $info_value) = $data;
if ($info_type == "template") { // Template-based export
$renderer->template = $info_value;
}
}
return false;
}
}