thumbnails.php
7.2 KB
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
<?php
/*
* $Id: $
*
* The contents of this file are subject to the KnowledgeTree
* Commercial Editions On-Premise License ("License");
* You may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.knowledgetree.com/about/legal/
* The terms of this license may change from time to time and the latest
* license will be published from time to time at the above Internet address.
*
* This edition of the KnowledgeTree software
* is NOT licensed to you under Open Source terms.
* You may not redistribute this source code.
* For more information please see the License above.
*
* (c) 2008 KnowledgeTree Inc.
* Portions copyright The Jam Warehouse Software (Pty) Ltd;
* All Rights Reserved.
*
*/
require_once(KT_LIB_DIR . "/actions/documentviewlet.inc.php");
require_once(KT_DIR . '/search2/documentProcessor/documentProcessor.inc.php');
/**
* Generates thumbnails of documents using the pdf converter output
* Dependent on the pdfConverter
*/
class thumbnailGenerator extends BaseProcessor
{
public $order = 3;
protected $namespace = 'thumbnails.generator.processor';
/**
* Constructor
*
* @return thumbnailGenerator
*/
public function thumbnailGenerator()
{
}
/**
* Gets the document path and calls the generator function
*
* @return boolean
*/
public function processDocument()
{
// do the generation
$res = $this->generateThumbnail();
return $res;
}
/**
* The supported mime types for the converter.
*
* @return array
*/
public function getSupportedMimeTypes()
{
// $aAcceptedMimeTypes = array('doc', 'ods', 'odt', 'ott', 'txt', 'rtf', 'sxw', 'stw',
// // 'html', 'htm',
// 'xml' , 'pdb', 'psw', 'ods', 'ots', 'sxc',
// 'stc', 'dif', 'dbf', 'xls', 'xlt', 'slk', 'csv', 'pxl',
// 'odp', 'otp', 'sxi', 'sti', 'ppt', 'pot', 'sxd', 'odg',
// 'otg', 'std', 'asc');
// taken from the original list of accepted types in the pdf generator action
$mime_types = array();
$mime_types[] = 'text/plain';
$mime_types[] = 'text/html';
$mime_types[] = 'text/csv';
$mime_types[] = 'text/rtf';
// Office OLE2 - 2003, XP, etc
$mime_types[] = 'application/msword';
$mime_types[] = 'application/vnd.ms-powerpoint';
$mime_types[] = 'application/vnd.ms-excel';
// Star Office
$mime_types[] = 'application/vnd.sun.xml.writer';
$mime_types[] = 'application/vnd.sun.xml.writer.template';
$mime_types[] = 'application/vnd.sun.xml.calc';
$mime_types[] = 'application/vnd.sun.xml.calc.template';
$mime_types[] = 'application/vnd.sun.xml.draw';
$mime_types[] = 'application/vnd.sun.xml.draw.template';
$mime_types[] = 'application/vnd.sun.xml.impress';
$mime_types[] = 'application/vnd.sun.xml.impress.template';
// Open Office
$mime_types[] = 'application/vnd.oasis.opendocument.text';
$mime_types[] = 'application/vnd.oasis.opendocument.text-template';
$mime_types[] = 'application/vnd.oasis.opendocument.graphics';
$mime_types[] = 'application/vnd.oasis.opendocument.graphics-template';
$mime_types[] = 'application/vnd.oasis.opendocument.presentation';
$mime_types[] = 'application/vnd.oasis.opendocument.presentation-template';
$mime_types[] = 'application/vnd.oasis.opendocument.spreadsheet';
$mime_types[] = 'application/vnd.oasis.opendocument.spreadsheet-template';
/* OO3
// Office 2007
$mime_types[] = 'application/vnd.openxmlformats-officedocument.wordprocessingml.document';
$mime_types[] = 'application/vnd.openxmlformats-officedocument.wordprocessingml.template';
$mime_types[] = 'application/vnd.openxmlformats-officedocument.presentationml.template';
$mime_types[] = 'application/vnd.openxmlformats-officedocument.presentationml.slideshow';
$mime_types[] = 'application/vnd.openxmlformats-officedocument.presentationml.presentation';
$mime_types[] = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
$mime_types[] = 'application/vnd.openxmlformats-officedocument.spreadsheetml.template';
*/
return $mime_types;
}
/**
* Generates the thumbnail from the pdf
*
* @return boolean
*/
private function generateThumbnail()
{
/*
The thumbnail is displayed in the info panel and the document view
The info panel is in the plugin ktcore/documentpreview/
- add a hook in there but build the functionality in this plugin ie keep the plugins separate and don't create dependencies
- if the thumbnail plugin is disabled then maybe display a normal sized info panel
The document view will display the thumbnail on the right in a document viewlet similar to the workflow viewlet
- check out ktcore/KTDocumentViewlets.php
- viewlet class is below
*/
global $default;
$pdfDir = $default->pdfDirectory;
$pdfFile = $pdfDir .'/'. $this->document->iId.'.pdf';
$thumbnaildir = $pdfDir."/thumbnails";
$thumbnailfile = $thumbnaildir.'/'.$this->document->iId.'.jpg';
//if thumbail dir does not exist, generate one
if (!file_exists($thumbnaildir)) {
mkdir($thumbnaildir, 0755);
}
// if there is no pdf that exists - hop out
if(!file_exists($pdfFile)){
global $default;
$default->log->debug('Thumbnail Generator Plugin: PDF file does not exist, cannot generate a thumbnail');
return false;
}
// if a previous version of the thumbnail exists - delete it
if (file_exists($thumbnailfile)) {
@unlink($thumbnailfile);
}
// do generation
if (extension_loaded('imagick')) {
$result= shell_exec("convert -size 200x200 {$pdfFile}[0] -resize 200x200 $thumbnailfile");
return true;
}else{
$default->log->debug('Thumbnail Generator Plugin: Imagemagick not installed, cannot generate a thumbnail');
return false;
}
}
}
class ThumbnailViewlet extends KTDocumentViewlet {
var $sName = 'thumbnail.viewlets';
public function display_viewlet($documentId) {
global $default;
$oKTTemplating =& KTTemplating::getSingleton();
$oTemplate =& $oKTTemplating->loadTemplate('thumbnail_viewlet');
if (is_null($oTemplate)) return '';
$pdfDir = $default->pdfDirectory;
$thumbnailfile = $pdfDir . '/thumbnails/'.$documentId.'.jpg';
// check that file exists
if (!file_exists($thumbnailfile)) return '';
// NOTE this is to turn the config setting for the PDF directory into a proper URL and not a path
$thumbnailUrl = str_replace($default->varDirectory, 'var/', $thumbnailfile);
$oTemplate->setData(array('thumbnail' => $thumbnailUrl));
return $oTemplate->render();
}
public function get_width($documentId){
global $default;
$pdfDir = $default->pdfDirectory;
$thumbnailfile = $pdfDir . '/thumbnails/'.$documentId.'.jpg';
$size = getimagesize($thumbnailfile);
return $size[0];
}
}
?>