xref: /plugin/mediathumbnails/syntax.php (revision 6bc8b42d4814566d2a1d78a1c59e0eb1b6f84577)
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
14bbf77476Sterniteclass syntax_plugin_mediathumbnails extends DokuWiki_Syntax_Plugin {
15bbf77476Sternite
16bbf77476Sternite	/**
17bbf77476Sternite     * @return string Syntax mode type
18bbf77476Sternite     */
19bbf77476Sternite    public function getType()
20bbf77476Sternite    {
21bbf77476Sternite        return 'substition';
22bbf77476Sternite    }
23bbf77476Sternite
24bbf77476Sternite    /**
25bbf77476Sternite     * @return string Paragraph type
26bbf77476Sternite     */
27bbf77476Sternite    public function getPType()
28bbf77476Sternite    {
29bbf77476Sternite        return 'normal';
30bbf77476Sternite    }
31bbf77476Sternite
32bbf77476Sternite    /**
33bbf77476Sternite     * @return int Sort order - Low numbers go before high numbers
34bbf77476Sternite     */
35bbf77476Sternite    public function getSort()
36bbf77476Sternite    {
37bbf77476Sternite        return 1;
38bbf77476Sternite    }
39bbf77476Sternite
40bbf77476Sternite    /**
41bbf77476Sternite     * Connect lookup pattern to lexer.
42bbf77476Sternite     *
43bbf77476Sternite     * @param string $mode Parser mode
44bbf77476Sternite     */
45bbf77476Sternite    public function connectTo($mode)
46bbf77476Sternite    {
47bbf77476Sternite		$this->Lexer->addSpecialPattern("{{thumbnail>.+?}}", $mode, substr(get_class($this), 7));
48bbf77476Sternite	}
49bbf77476Sternite
50bbf77476Sternite    /**
51bbf77476Sternite     * Handle matches of the mediathumbnails syntax
52bbf77476Sternite     *
53bbf77476Sternite     * @param string       $match   The match of the syntax
54bbf77476Sternite     * @param int          $state   The state of the handler
55bbf77476Sternite     * @param int          $pos     The position in the document
56bbf77476Sternite     * @param Doku_Handler $handler The handler
57bbf77476Sternite     *
58bbf77476Sternite     * @return array Data for the renderer
59bbf77476Sternite     */
60bbf77476Sternite    public function handle($match, $state, $pos, Doku_Handler $handler)
61bbf77476Sternite    {
62da77d72dSternite		// Locate the given media file and check if it can be opened as zip
6332095c04Sternite		$mediapath_file = substr($match, 12, -2); //strip markup
64b8b45234Sternite		$filepath_local_file = mediaFN($mediapath_file);
65bbf77476Sternite
66bbf77476Sternite		$zip = new ZipArchive;
67b8b45234Sternite		if ($zip->open($filepath_local_file) !== TRUE) {
68da77d72dSternite			// media file does not exist
69da77d72dSternite			return array($mediapath_file);
70bbf77476Sternite		}
71bbf77476Sternite
72da77d72dSternite		// Check all possible paths (configured in configuration key 'thumb_paths') if there is a file available
73da77d72dSternite		$thumb_paths_to_investigate = $this->getConf('thumb_paths');
74da77d72dSternite
75da77d72dSternite		foreach($thumb_paths_to_investigate as $thumbnail_path) {
76da77d72dSternite			$thumbnail_ending = strrchr($thumbnail_path,'.');
77da77d72dSternite
78b8b45234Sternite			if ($zip->locateName($thumbnail_path) !== false) {
79bbf77476Sternite				// thumbnail file exists
80b8b45234Sternite				$fp = $zip->getStream($thumbnail_path);
81bbf77476Sternite				if(!$fp) {
82bbf77476Sternite					return array();
83bbf77476Sternite				}
84bbf77476Sternite
85bbf77476Sternite				$thumbnaildata = '';
86bbf77476Sternite				while (!feof($fp)) {
87bbf77476Sternite					$thumbnaildata .= fread($fp, 8192);
88bbf77476Sternite				}
89bbf77476Sternite
90bbf77476Sternite				fclose($fp);
91bbf77476Sternite
92bbf77476Sternite				// write thumbnail file to media folder
93b8b45234Sternite				$filedir = dirname($filepath_local_file);
94b8b45234Sternite				$filename = basename($filepath_local_file);
95b8b45234Sternite				$extended_filename = substr($filename,0,strrpos($filename,'.')).".thumbnail".$thumbnail_ending;
96bbf77476Sternite
97bbf77476Sternite				$filepath_thumbnail = $filedir . DIRECTORY_SEPARATOR . $extended_filename;
98bbf77476Sternite				file_put_contents($filepath_thumbnail, $thumbnaildata);
99bbf77476Sternite
100bbf77476Sternite				// give media path to renderer
10132095c04Sternite				$mediapath_thumbnail = substr($mediapath_file,0,strrpos($mediapath_file,':')) . ":" . $extended_filename;
10232095c04Sternite				return array($mediapath_file, $mediapath_thumbnail);
103bbf77476Sternite			}
104da77d72dSternite		}
105bbf77476Sternite
106da77d72dSternite		return array($mediapath_file);
107bbf77476Sternite    }
108bbf77476Sternite
109bbf77476Sternite    /**
110bbf77476Sternite     * Render xhtml output or metadata
111bbf77476Sternite     *
112bbf77476Sternite     * @param string        $mode     Renderer mode (supported modes: xhtml)
113bbf77476Sternite     * @param Doku_Renderer $renderer The renderer
114bbf77476Sternite     * @param array         $data     The data from the handler() function
115bbf77476Sternite     *
116bbf77476Sternite     * @return bool If rendering was successful.
117bbf77476Sternite     */
118bbf77476Sternite    public function render($mode, Doku_Renderer $renderer, $data)
119bbf77476Sternite    {
120967904f1Sternite		list ($mediapath_file, $mediapath_thumbnail) = $data;
121bbf77476Sternite
122bbf77476Sternite        if ($mode == 'xhtml') {
123bbf77476Sternite
124da77d72dSternite			// check if a thumbnail file was found
125da77d72dSternite			if (!$mediapath_thumbnail) {
126da77d72dSternite				if ($this->getConf('show_no_thumb_error')) {
127da77d72dSternite					$renderer->doc .= trim($this->getConf('no_thumb_error_message')) . " " . $mediapath_file;
128da77d72dSternite					return true;
129da77d72dSternite				} else {
130da77d72dSternite					return false;
131da77d72dSternite				}
132da77d72dSternite			}
133da77d72dSternite
134bbf77476Sternite			$src = ml($mediapath_thumbnail,array());
135bbf77476Sternite
136bbf77476Sternite			$i             = array();
137b8b45234Sternite			$i['width']    = $this->getConf('thumb_width');
1383ac8d5b9Sternite			//$i['height']   = '';
1393ac8d5b9Sternite			$i['title']      = $mediapath_file;
140bbf77476Sternite			$i['class']    = 'tn';
141bbf77476Sternite			$iatt = buildAttributes($i);
142bbf77476Sternite
143*6bc8b42dSternite			$renderer->doc .= 	($this->getConf('link_to_media_file') ? '<a href="/lib/exe/fetch.php?media=' . $mediapath_file . '">' : '') .
14432095c04Sternite								'<img src="'.$src.'" '.$iatt.' />' .
145*6bc8b42dSternite								($this->getConf('link_to_media_file') ? '</a>' : '');
146bbf77476Sternite            return true;
147bbf77476Sternite
148bbf77476Sternite        } elseif ($mode == 'odt') {
149bbf77476Sternite
150bbf77476Sternite			// TODO: yet to implement
151bbf77476Sternite			$renderer->cdata("");
152bbf77476Sternite			return true;
153bbf77476Sternite
154bbf77476Sternite		}
155bbf77476Sternite
156bbf77476Sternite        return false;
157bbf77476Sternite    }
158bbf77476Sternite}
159bbf77476Sternite
160