1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-04 20:01:00 +01:00

Add image support for diffusion file view

Summary:
render image as an image tag in diffusion view.

Test Plan:
1. Image shows up correctly. 2. Non-image file still works
fine.

Reviewed By: epriestley
Reviewers: epriestley
CC: epriestley
Differential Revision: 94
This commit is contained in:
jungejason 2011-04-01 13:42:00 -07:00
parent 64cd4f969d
commit d23696a457

View file

@ -18,6 +18,14 @@
class DiffusionBrowseFileController extends DiffusionController { class DiffusionBrowseFileController extends DiffusionController {
protected $imageTypes = array(
'png' => 'image/png',
'gif' => 'image/gif',
'ico' => 'image/png',
'jpg' => 'image/jpeg',
'jpeg'=> 'image/jpeg'
);
public function processRequest() { public function processRequest() {
// Build the view selection form. // Build the view selection form.
@ -90,7 +98,23 @@ class DiffusionBrowseFileController extends DiffusionController {
$file_query->setNeedsBlame($needs_blame); $file_query->setNeedsBlame($needs_blame);
$file_query->loadFileContent(); $file_query->loadFileContent();
// TODO: image $drequest = $this->getDiffusionRequest();
$path = $drequest->getPath();
$image_type = $this->getImageType($path);
if ($image_type && !$selected) {
$data = $file_query->getRawData();
$corpus = phutil_render_tag(
'img',
array(
'style' => 'padding-bottom: 10px',
'src' => 'data:'.$image_type.';base64,'.base64_encode($data),
)
);
return $corpus;
}
// TODO: blame of blame. // TODO: blame of blame.
switch ($selected) { switch ($selected) {
case 'plain': case 'plain':
@ -136,8 +160,6 @@ class DiffusionBrowseFileController extends DiffusionController {
list($text_list, $rev_list, $blame_dict) = $file_query->getBlameData(); list($text_list, $rev_list, $blame_dict) = $file_query->getBlameData();
$drequest = $this->getDiffusionRequest();
$path = $drequest->getPath();
$highlightEngine = new PhutilDefaultSyntaxHighlighterEngine(); $highlightEngine = new PhutilDefaultSyntaxHighlighterEngine();
$text_list = explode("\n", $highlightEngine->highlightSource($path, $text_list = explode("\n", $highlightEngine->highlightSource($path,
@ -255,4 +277,18 @@ class DiffusionBrowseFileController extends DiffusionController {
); );
} }
/**
* Returns a content-type corrsponding to an image file extension
*
* @param string $path File path
* @return mixed A content-type string or NULL if path doesn't end with a
* recognized image extension
*/
public function getImageType($path) {
$ext = pathinfo($path);
$ext = $ext['extension'];
return idx($this->imageTypes, $ext);
}
} }