2013-05-28 13:29:01 +04:00
|
|
|
<?php
|
|
|
|
/**
|
2016-07-21 18:07:57 +03:00
|
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
|
|
*
|
2015-03-26 13:44:34 +03:00
|
|
|
* @author Georg Ehrke <georg@owncloud.com>
|
2016-07-21 18:07:57 +03:00
|
|
|
* @author Joas Schilling <coding@schilljs.com>
|
2015-10-05 21:54:56 +03:00
|
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
2015-03-26 13:44:34 +03:00
|
|
|
* @author Nmz <nemesiz@nmz.lt>
|
2016-07-21 19:13:36 +03:00
|
|
|
* @author Robin Appelman <robin@icewind.nl>
|
2015-03-26 13:44:34 +03:00
|
|
|
* @author Thomas Müller <thomas.mueller@tmit.eu>
|
|
|
|
*
|
|
|
|
* @license AGPL-3.0
|
|
|
|
*
|
|
|
|
* This code is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License, version 3,
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License, version 3,
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
*
|
2013-05-28 13:29:01 +04:00
|
|
|
*/
|
2013-05-29 14:33:24 +04:00
|
|
|
namespace OC\Preview;
|
|
|
|
|
2013-05-29 15:11:43 +04:00
|
|
|
class TXT extends Provider {
|
2014-11-27 21:40:23 +03:00
|
|
|
/**
|
|
|
|
* {@inheritDoc}
|
|
|
|
*/
|
2013-05-29 15:03:33 +04:00
|
|
|
public function getMimeType() {
|
2013-10-11 02:25:34 +04:00
|
|
|
return '/text\/plain/';
|
2013-05-28 13:29:01 +04:00
|
|
|
}
|
|
|
|
|
2014-07-30 18:29:18 +04:00
|
|
|
/**
|
2014-11-27 21:40:23 +03:00
|
|
|
* {@inheritDoc}
|
2014-07-30 18:29:18 +04:00
|
|
|
*/
|
2015-03-12 14:20:39 +03:00
|
|
|
public function isAvailable(\OCP\Files\FileInfo $file) {
|
2015-05-27 15:11:33 +03:00
|
|
|
return $file->getSize() > 0;
|
2014-07-30 18:29:18 +04:00
|
|
|
}
|
|
|
|
|
2013-10-11 02:25:34 +04:00
|
|
|
/**
|
2014-11-27 21:40:23 +03:00
|
|
|
* {@inheritDoc}
|
2013-10-11 02:25:34 +04:00
|
|
|
*/
|
2013-05-29 15:03:33 +04:00
|
|
|
public function getThumbnail($path, $maxX, $maxY, $scalingup, $fileview) {
|
2013-05-28 13:29:01 +04:00
|
|
|
$content = $fileview->fopen($path, 'r');
|
2014-10-02 13:47:39 +04:00
|
|
|
$content = stream_get_contents($content,3000);
|
2013-05-28 13:29:01 +04:00
|
|
|
|
2013-08-15 15:25:45 +04:00
|
|
|
//don't create previews of empty text files
|
2013-08-14 23:20:03 +04:00
|
|
|
if(trim($content) === '') {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-05-28 13:29:01 +04:00
|
|
|
$lines = preg_split("/\r\n|\n|\r/", $content);
|
|
|
|
|
2015-09-30 11:49:48 +03:00
|
|
|
$fontSize = ($maxX) ? (int) ((5 / 32) * $maxX) : 5; //5px
|
2013-07-30 14:29:12 +04:00
|
|
|
$lineSize = ceil($fontSize * 1.25);
|
2013-05-28 13:29:01 +04:00
|
|
|
|
|
|
|
$image = imagecreate($maxX, $maxY);
|
2013-07-30 14:29:12 +04:00
|
|
|
imagecolorallocate($image, 255, 255, 255);
|
|
|
|
$textColor = imagecolorallocate($image, 0, 0, 0);
|
2013-05-28 13:29:01 +04:00
|
|
|
|
2014-06-10 19:29:40 +04:00
|
|
|
$fontFile = __DIR__;
|
|
|
|
$fontFile .= '/../../../core';
|
|
|
|
$fontFile .= '/fonts/OpenSans-Regular.ttf';
|
|
|
|
|
2014-07-28 13:56:43 +04:00
|
|
|
$canUseTTF = function_exists('imagettftext');
|
|
|
|
|
2013-05-29 15:03:33 +04:00
|
|
|
foreach($lines as $index => $line) {
|
2013-05-28 13:29:01 +04:00
|
|
|
$index = $index + 1;
|
|
|
|
|
|
|
|
$x = (int) 1;
|
2014-06-10 19:29:40 +04:00
|
|
|
$y = (int) ($index * $lineSize);
|
2013-05-28 13:29:01 +04:00
|
|
|
|
2014-07-28 13:56:43 +04:00
|
|
|
if ($canUseTTF === true) {
|
|
|
|
imagettftext($image, $fontSize, 0, $x, $y, $textColor, $fontFile, $line);
|
|
|
|
} else {
|
|
|
|
$y -= $fontSize;
|
|
|
|
imagestring($image, 1, $x, $y, $line, $textColor);
|
|
|
|
}
|
2013-05-28 13:29:01 +04:00
|
|
|
|
2013-07-30 14:29:12 +04:00
|
|
|
if(($index * $lineSize) >= $maxY) {
|
2013-05-28 13:29:01 +04:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$image = new \OC_Image($image);
|
2013-05-28 13:31:48 +04:00
|
|
|
|
2013-06-11 12:56:16 +04:00
|
|
|
return $image->valid() ? $image : false;
|
2013-05-28 13:29:01 +04:00
|
|
|
}
|
|
|
|
}
|