xref: /plugin/mediathumbnails/syntax.php (revision 2b9233e23d5a9d8495894e671495925f651635c3)
1bbf77476Sternite<?php
2bbf77476Sternite/**
3bbf77476Sternite * DokuWiki Plugin mediathumbnails (Syntax Component)
4bbf77476Sternite *
5bbf77476Sternite * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html
6bbf77476Sternite * @author  Thomas Schäfer <thomas.schaefer@itschert.net>
7bbf77476Sternite */
8bbf77476Sternite
9bbf77476Sternite// must be run within Dokuwiki
10bbf77476Sterniteif (!defined('DOKU_INC')) {
11bbf77476Sternite    die();
12bbf77476Sternite}
13bbf77476Sternite
1447d2d32aSterniterequire('thumbnail.php');
1547d2d32aSternite
16bbf77476Sterniteclass syntax_plugin_mediathumbnails extends DokuWiki_Syntax_Plugin {
17bbf77476Sternite
18bbf77476Sternite	/**
19bbf77476Sternite     * @return string Syntax mode type
20bbf77476Sternite     */
21bbf77476Sternite    public function getType()
22bbf77476Sternite    {
23bbf77476Sternite        return 'substition';
24bbf77476Sternite    }
25bbf77476Sternite
26bbf77476Sternite    /**
27bbf77476Sternite     * @return string Paragraph type
28bbf77476Sternite     */
29bbf77476Sternite    public function getPType()
30bbf77476Sternite    {
31bbf77476Sternite        return 'normal';
32bbf77476Sternite    }
33bbf77476Sternite
34bbf77476Sternite    /**
35bbf77476Sternite     * @return int Sort order - Low numbers go before high numbers
36bbf77476Sternite     */
37bbf77476Sternite    public function getSort()
38bbf77476Sternite    {
39bbf77476Sternite        return 1;
40bbf77476Sternite    }
41bbf77476Sternite
42bbf77476Sternite    /**
43bbf77476Sternite     * Connect lookup pattern to lexer.
44bbf77476Sternite     *
45bbf77476Sternite     * @param string $mode Parser mode
46bbf77476Sternite     */
47bbf77476Sternite    public function connectTo($mode)
48bbf77476Sternite    {
49bbf77476Sternite		$this->Lexer->addSpecialPattern("{{thumbnail>.+?}}", $mode, substr(get_class($this), 7));
50bbf77476Sternite	}
51bbf77476Sternite
52bbf77476Sternite    /**
53bbf77476Sternite     * Handle matches of the mediathumbnails syntax
54bbf77476Sternite     *
55bbf77476Sternite     * @param string       $match   The match of the syntax
56bbf77476Sternite     * @param int          $state   The state of the handler
57bbf77476Sternite     * @param int          $pos     The position in the document
58bbf77476Sternite     * @param Doku_Handler $handler The handler
59bbf77476Sternite     *
60bbf77476Sternite     * @return array Data for the renderer
61bbf77476Sternite     */
62bbf77476Sternite    public function handle($match, $state, $pos, Doku_Handler $handler)
63bbf77476Sternite    {
64da77d72dSternite		// Locate the given media file and check if it can be opened as zip
65*2b9233e2Sternite		$documenttype_command = substr($match, 12, -2); //strip markup
66*2b9233e2Sternite
67*2b9233e2Sternite        // if the command is using a pipe separator, the mediapath file must be extracted. As of now, the text behind the pipe will be ignored!
68*2b9233e2Sternite        $params = explode("|", $documenttype_command);
69*2b9233e2Sternite
70*2b9233e2Sternite        $mediapath_file = $params[0];
71bbf77476Sternite
72a2549de1Sternite		$thumb = new thumbnail($mediapath_file,$this);
73a2549de1Sternite		if ($thumb->create()) {
74a2549de1Sternite			return array($mediapath_file,$thumb->getMediapath());
75da77d72dSternite		}
76bbf77476Sternite
77da77d72dSternite		return array($mediapath_file);
78bbf77476Sternite    }
79bbf77476Sternite
80bbf77476Sternite    /**
81bbf77476Sternite     * Render xhtml output or metadata
82bbf77476Sternite     *
83bbf77476Sternite     * @param string        $mode     Renderer mode (supported modes: xhtml)
84bbf77476Sternite     * @param Doku_Renderer $renderer The renderer
85bbf77476Sternite     * @param array         $data     The data from the handler() function
86bbf77476Sternite     *
87bbf77476Sternite     * @return bool If rendering was successful.
88bbf77476Sternite     */
89bbf77476Sternite    public function render($mode, Doku_Renderer $renderer, $data)
90bbf77476Sternite    {
91967904f1Sternite		list ($mediapath_file, $mediapath_thumbnail) = $data;
92bbf77476Sternite
93bbf77476Sternite        if ($mode == 'xhtml') {
94bbf77476Sternite
95da77d72dSternite			// check if a thumbnail file was found
96da77d72dSternite			if (!$mediapath_thumbnail) {
972f64379eSternite				if ($this->getConf('show_missing_thumb_error')) {
98da77d72dSternite					$renderer->doc .= trim($this->getConf('no_thumb_error_message')) . " " . $mediapath_file;
99da77d72dSternite					return true;
100da77d72dSternite				} else {
101da77d72dSternite					return false;
102da77d72dSternite				}
103da77d72dSternite			}
104da77d72dSternite
105bbf77476Sternite			$src = ml($mediapath_thumbnail,array());
106bbf77476Sternite
107bbf77476Sternite			$i          = array();
108086d90eeSternite
1093ac8d5b9Sternite			$i['title'] = $mediapath_file;
110086d90eeSternite			$i['style'] = "max-width:".$this->getConf('thumb_max_dimension')."px;max-height:".$this->getConf('thumb_max_dimension')."px";
111086d90eeSternite
112bbf77476Sternite			$iatt = buildAttributes($i);
113bbf77476Sternite
1146bc8b42dSternite			$renderer->doc .= 	($this->getConf('link_to_media_file') ? '<a href="/lib/exe/fetch.php?media=' . $mediapath_file . '">' : '') .
11532095c04Sternite								'<img src="'.$src.'" '.$iatt.' />' .
1166bc8b42dSternite								($this->getConf('link_to_media_file') ? '</a>' : '');
117bbf77476Sternite            return true;
118bbf77476Sternite
119bbf77476Sternite        } elseif ($mode == 'odt') {
120bbf77476Sternite
121bbf77476Sternite			// TODO: yet to implement
122bbf77476Sternite			$renderer->cdata("");
123bbf77476Sternite			return true;
124bbf77476Sternite
125bbf77476Sternite		}
126bbf77476Sternite
127bbf77476Sternite        return false;
128bbf77476Sternite    }
129bbf77476Sternite}