-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsyntax.php
124 lines (102 loc) · 3.14 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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
/**
* DokuWiki Plugin mediathumbnails (Syntax Component)
*
* @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html
* @author Thomas Schäfer <thomas.schaefer@itschert.net>
*/
// must be run within Dokuwiki
if (!defined('DOKU_INC')) {
die();
}
require('thumbnail.php');
class syntax_plugin_mediathumbnails extends DokuWiki_Syntax_Plugin {
/**
* @return string Syntax mode type
*/
public function getType()
{
return 'substition';
}
/**
* @return string Paragraph type
*/
public function getPType()
{
return 'normal';
}
/**
* @return int Sort order - Low numbers go before high numbers
*/
public function getSort()
{
return 1;
}
/**
* Connect lookup pattern to lexer.
*
* @param string $mode Parser mode
*/
public function connectTo($mode)
{
$this->Lexer->addSpecialPattern("{{thumbnail>.+?}}", $mode, substr(get_class($this), 7));
}
/**
* Handle matches of the mediathumbnails syntax
*
* @param string $match The match of the syntax
* @param int $state The state of the handler
* @param int $pos The position in the document
* @param Doku_Handler $handler The handler
*
* @return array Data for the renderer
*/
public function handle($match, $state, $pos, Doku_Handler $handler)
{
// Locate the given media file and check if it can be opened as zip
$mediapath_file = substr($match, 12, -2); //strip markup
$thumb = new thumbnail($mediapath_file,$this);
if ($thumb->create()) {
return array($mediapath_file,$thumb->getMediapath());
}
return array($mediapath_file);
}
/**
* Render xhtml output or metadata
*
* @param string $mode Renderer mode (supported modes: xhtml)
* @param Doku_Renderer $renderer The renderer
* @param array $data The data from the handler() function
*
* @return bool If rendering was successful.
*/
public function render($mode, Doku_Renderer $renderer, $data)
{
list ($mediapath_file, $mediapath_thumbnail) = $data;
if ($mode == 'xhtml') {
// check if a thumbnail file was found
if (!$mediapath_thumbnail) {
if ($this->getConf('show_missing_thumb_error')) {
$renderer->doc .= trim($this->getConf('no_thumb_error_message')) . " " . $mediapath_file;
return true;
} else {
return false;
}
}
$src = ml($mediapath_thumbnail,array());
$i = array();
$i['title'] = $mediapath_file;
$i['style'] = "max-width:".$this->getConf('thumb_max_dimension')."px;max-height:".$this->getConf('thumb_max_dimension')."px";
$iatt = buildAttributes($i);
$renderer->doc .= ($this->getConf('link_to_media_file') ? '<a href="/lib/exe/fetch.php?media=' . $mediapath_file . '">' : '') .
'<img src="'.$src.'" '.$iatt.' />' .
($this->getConf('link_to_media_file') ? '</a>' : '');
return true;
} elseif ($mode == 'odt') {
// TODO: yet to implement
$renderer->cdata("");
return true;
}
return false;
}
}