xref: /plugin/mediathumbnails/syntax.php (revision 120df3425e40dc2703dabc3d3f879ef45d660015)
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
652b9233e2Sternite		$documenttype_command = substr($match, 12, -2); //strip markup
662b9233e2Sternite
672b9233e2Sternite        // 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!
682b9233e2Sternite        $params = explode("|", $documenttype_command);
692b9233e2Sternite
702b9233e2Sternite        $mediapath_file = $params[0];
71bbf77476Sternite
72*120df342Sternite        $caption = $mediapath_file;
73*120df342Sternite
74*120df342Sternite        if (sizeof($params) > 1) {
75*120df342Sternite            $caption = $params[1];
76*120df342Sternite        }
77*120df342Sternite
78a2549de1Sternite		$thumb = new thumbnail($mediapath_file,$this);
79a2549de1Sternite		if ($thumb->create()) {
80*120df342Sternite			return array($mediapath_file,$thumb->getMediapath(),$caption);
81da77d72dSternite		}
82bbf77476Sternite
83da77d72dSternite		return array($mediapath_file);
84bbf77476Sternite    }
85bbf77476Sternite
86bbf77476Sternite    /**
87bbf77476Sternite     * Render xhtml output or metadata
88bbf77476Sternite     *
89bbf77476Sternite     * @param string        $mode     Renderer mode (supported modes: xhtml)
90bbf77476Sternite     * @param Doku_Renderer $renderer The renderer
91bbf77476Sternite     * @param array         $data     The data from the handler() function
92bbf77476Sternite     *
93bbf77476Sternite     * @return bool If rendering was successful.
94bbf77476Sternite     */
95bbf77476Sternite    public function render($mode, Doku_Renderer $renderer, $data)
96bbf77476Sternite    {
97*120df342Sternite		list ($mediapath_file, $mediapath_thumbnail, $caption) = $data;
98bbf77476Sternite
99bbf77476Sternite        if ($mode == 'xhtml') {
100bbf77476Sternite
101da77d72dSternite			// check if a thumbnail file was found
102da77d72dSternite			if (!$mediapath_thumbnail) {
1032f64379eSternite				if ($this->getConf('show_missing_thumb_error')) {
104da77d72dSternite					$renderer->doc .= trim($this->getConf('no_thumb_error_message')) . " " . $mediapath_file;
105da77d72dSternite					return true;
106da77d72dSternite				} else {
107da77d72dSternite					return false;
108da77d72dSternite				}
109da77d72dSternite			}
110da77d72dSternite
111bbf77476Sternite			$src = ml($mediapath_thumbnail,array());
112bbf77476Sternite
113bbf77476Sternite			$i          = array();
114086d90eeSternite
1153ac8d5b9Sternite			$i['title'] = $mediapath_file;
116086d90eeSternite			$i['style'] = "max-width:".$this->getConf('thumb_max_dimension')."px;max-height:".$this->getConf('thumb_max_dimension')."px";
117086d90eeSternite
118bbf77476Sternite			$iatt = buildAttributes($i);
119bbf77476Sternite
1206bc8b42dSternite			$renderer->doc .= 	($this->getConf('link_to_media_file') ? '<a href="/lib/exe/fetch.php?media=' . $mediapath_file . '">' : '') .
121*120df342Sternite								'<img src="'.$src.'" title="'.$caption.'" '.$iatt.' />' .
1226bc8b42dSternite								($this->getConf('link_to_media_file') ? '</a>' : '');
123bbf77476Sternite            return true;
124bbf77476Sternite
125bbf77476Sternite        } elseif ($mode == 'odt') {
126bbf77476Sternite
127bbf77476Sternite			// TODO: yet to implement
128bbf77476Sternite			$renderer->cdata("");
129bbf77476Sternite			return true;
130bbf77476Sternite
131bbf77476Sternite		}
132bbf77476Sternite
133bbf77476Sternite        return false;
134bbf77476Sternite    }
135bbf77476Sternite}