-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsyntax.php
102 lines (78 loc) · 3.2 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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<?php
/**
* Editor Plugin: displays links to all wiki pages edited by a given user or ip
*
* @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
* @author Esther Brunner <[email protected]>
*/
// must be run within Dokuwiki
if(!defined('DOKU_INC')) die();
if (!defined('DOKU_LF')) define('DOKU_LF', "\n");
if (!defined('DOKU_TAB')) define('DOKU_TAB', "\t");
if (!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN', DOKU_INC.'lib/plugins/');
require_once(DOKU_PLUGIN.'syntax.php');
class syntax_plugin_editor extends DokuWiki_Syntax_Plugin {
function getType() { return 'substition'; }
function getPType() { return 'block'; }
function getSort() { return 309; }
function connectTo($mode) {
$this->Lexer->addSpecialPattern('\{\{editor>.+?\}\}',$mode,'plugin_editor');
}
function handle($match, $state, $pos, Doku_Handler $handler) {
global $ID;
$match = substr($match, 9, -2); // strip {{editor> from start and }} from end
list($match, $flags) = explode('&', $match, 2);
$flags = explode('&', $flags);
list($match, $refine) = explode(' ', $match, 2);
list($ns, $user) = explode('?', $match);
if (!$user) {
$user = $ns;
$ns = '';
}
if (($ns == '*') || ($ns == ':')) $ns = '';
elseif ($ns == '.') $ns = getNS($ID);
else $ns = cleanID($ns);
return array($ns, trim($user), $flags, $refine);
}
function render($mode, Doku_Renderer $renderer, $data) {
list($ns, $user, $flags, $refine) = $data;
if ($user == '@USER@') $user = $_SERVER['REMOTE_USER'];
if ($my =& plugin_load('helper', 'editor')) $pages = $my->getEditor($ns, '', $user);
// use tag refinements?
if ($refine) {
if (plugin_isdisabled('tag') || (!$tag = plugin_load('helper', 'tag'))) {
msg('The Tag Plugin must be installed to use tag refinements.', -1);
} else {
$pages = $tag->tagRefine($pages, $refine);
}
}
if (!$pages) return true; // nothing to display
if ($mode == 'xhtml') {
// prevent caching to ensure content is always fresh
$renderer->info['cache'] = false;
// let Pagelist Plugin do the work for us
if (plugin_isdisabled('pagelist')
|| (!$pagelist =& plugin_load('helper', 'pagelist'))) {
msg('The Pagelist Plugin must be installed for editor lists to work.', -1);
return false;
}
// hide user column, unless for groups
if ($user[0] != '@') $pagelist->column['user'] = false;
$pagelist->setFlags($flags);
$pagelist->startList();
foreach ($pages as $page) {
$pagelist->addPage($page);
}
$renderer->doc .= $pagelist->finishList();
return true;
// for metadata renderer
} elseif ($mode == 'metadata') {
foreach ($pages as $page) {
$renderer->meta['relation']['references'][$page['id']] = true;
}
return true;
}
return false;
}
}
// vim:ts=4:sw=4:et:enc=utf-8: