From d23696a45705e3d0e7e162d33c522f3047748a0a Mon Sep 17 00:00:00 2001 From: jungejason Date: Fri, 1 Apr 2011 13:42:00 -0700 Subject: [PATCH] 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 --- .../file/DiffusionBrowseFileController.php | 42 +++++++++++++++++-- 1 file changed, 39 insertions(+), 3 deletions(-) diff --git a/src/applications/diffusion/controller/file/DiffusionBrowseFileController.php b/src/applications/diffusion/controller/file/DiffusionBrowseFileController.php index f2ac3271ae..c70ad1c9d2 100644 --- a/src/applications/diffusion/controller/file/DiffusionBrowseFileController.php +++ b/src/applications/diffusion/controller/file/DiffusionBrowseFileController.php @@ -18,6 +18,14 @@ 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() { // Build the view selection form. @@ -90,7 +98,23 @@ class DiffusionBrowseFileController extends DiffusionController { $file_query->setNeedsBlame($needs_blame); $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. switch ($selected) { case 'plain': @@ -136,8 +160,6 @@ class DiffusionBrowseFileController extends DiffusionController { list($text_list, $rev_list, $blame_dict) = $file_query->getBlameData(); - $drequest = $this->getDiffusionRequest(); - $path = $drequest->getPath(); $highlightEngine = new PhutilDefaultSyntaxHighlighterEngine(); $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); + } + }