Merge pull request #875 from Phosworks/U4-7312
Changed web api GetBigThumbnail to image processor
This commit is contained in:
@@ -144,31 +144,28 @@ function fileUploadController($scope, $element, $compile, imageHelper, fileManag
|
||||
};
|
||||
angular.module("umbraco")
|
||||
.controller('Umbraco.PropertyEditors.FileUploadController', fileUploadController)
|
||||
.run(function(mediaHelper, umbRequestHelper){
|
||||
.run(function(mediaHelper, umbRequestHelper, assetsService){
|
||||
if (mediaHelper && mediaHelper.registerFileResolver) {
|
||||
|
||||
//NOTE: The 'entity' can be either a normal media entity or an "entity" returned from the entityResource
|
||||
// they contain different data structures so if we need to query against it we need to be aware of this.
|
||||
mediaHelper.registerFileResolver("Umbraco.UploadField", function(property, entity, thumbnail){
|
||||
if (thumbnail) {
|
||||
|
||||
if (mediaHelper.detectIfImageByExtension(property.value)) {
|
||||
|
||||
var thumbnailUrl = umbRequestHelper.getApiUrl(
|
||||
"imagesApiBaseUrl",
|
||||
"GetBigThumbnail",
|
||||
[{ originalImagePath: property.value }]);
|
||||
|
||||
return thumbnailUrl;
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
|
||||
assetsService.load(["lib/moment/moment-with-locales.js"]).then(
|
||||
function () {
|
||||
//NOTE: The 'entity' can be either a normal media entity or an "entity" returned from the entityResource
|
||||
// they contain different data structures so if we need to query against it we need to be aware of this.
|
||||
mediaHelper.registerFileResolver("Umbraco.UploadField", function(property, entity, thumbnail){
|
||||
if (thumbnail) {
|
||||
if (mediaHelper.detectIfImageByExtension(property.value)) {
|
||||
//get default big thumbnail from image processor
|
||||
var thumbnailUrl = property.value + "?rnd=" + moment(entity.updateDate).format("YYYYMMDDHHmmss") + "&width=500";
|
||||
return thumbnailUrl;
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
else {
|
||||
return property.value;
|
||||
}
|
||||
});
|
||||
}
|
||||
else {
|
||||
return property.value;
|
||||
}
|
||||
});
|
||||
);
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
@@ -8,6 +8,7 @@ using Umbraco.Core;
|
||||
using Umbraco.Core.Configuration;
|
||||
using Umbraco.Core.IO;
|
||||
using Umbraco.Core.Media;
|
||||
using Umbraco.Core.Models;
|
||||
using Umbraco.Web.Mvc;
|
||||
using Umbraco.Web.WebApi;
|
||||
using Umbraco.Web.WebApi.Filters;
|
||||
@@ -36,15 +37,8 @@ namespace Umbraco.Web.Editors
|
||||
{
|
||||
return Request.CreateResponse(HttpStatusCode.NotFound);
|
||||
}
|
||||
var imageProp = media.Properties[Constants.Conventions.Media.File];
|
||||
if (imageProp == null)
|
||||
{
|
||||
return Request.CreateResponse(HttpStatusCode.NotFound);
|
||||
}
|
||||
|
||||
var imagePath = imageProp.Value.ToString();
|
||||
|
||||
return GetBigThumbnail(imagePath);
|
||||
return GetResized(media, 500);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -60,7 +54,7 @@ namespace Umbraco.Web.Editors
|
||||
if (string.IsNullOrWhiteSpace(originalImagePath))
|
||||
return Request.CreateResponse(HttpStatusCode.OK);
|
||||
|
||||
return GetResized(originalImagePath, 500, "big-thumb");
|
||||
return GetResized(originalImagePath, 500);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -79,15 +73,8 @@ namespace Umbraco.Web.Editors
|
||||
{
|
||||
return new HttpResponseMessage(HttpStatusCode.NotFound);
|
||||
}
|
||||
var imageProp = media.Properties[Constants.Conventions.Media.File];
|
||||
if (imageProp == null)
|
||||
{
|
||||
return new HttpResponseMessage(HttpStatusCode.NotFound);
|
||||
}
|
||||
|
||||
var imagePath = imageProp.Value.ToString();
|
||||
|
||||
return GetResized(imagePath, width);
|
||||
return GetResized( media, 500 );
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -101,75 +88,33 @@ namespace Umbraco.Web.Editors
|
||||
/// </remarks>
|
||||
public HttpResponseMessage GetResized(string imagePath, int width)
|
||||
{
|
||||
return GetResized(imagePath, width, Convert.ToString(width));
|
||||
var media = Services.MediaService.GetMediaByPath( imagePath );
|
||||
if (media == null)
|
||||
{
|
||||
return new HttpResponseMessage( HttpStatusCode.NotFound );
|
||||
}
|
||||
|
||||
return GetResized( media, 500 );
|
||||
}
|
||||
|
||||
//TODO: We should delegate this to ImageProcessing
|
||||
|
||||
/// <summary>
|
||||
/// Gets a resized image - if the requested max width is greater than the original image, only the original image will be returned.
|
||||
/// Gets a resized image by redirecting to ImageProcessor
|
||||
/// </summary>
|
||||
/// <param name="imagePath"></param>
|
||||
/// <param name="media"></param>
|
||||
/// <param name="width"></param>
|
||||
/// <param name="suffix"></param>
|
||||
/// <returns></returns>
|
||||
private HttpResponseMessage GetResized(string imagePath, int width, string suffix)
|
||||
{
|
||||
var mediaFileSystem = FileSystemProviderManager.Current.GetFileSystemProvider<MediaFileSystem>();
|
||||
var ext = Path.GetExtension(imagePath);
|
||||
|
||||
//we need to check if it is an image by extension
|
||||
if (UmbracoConfig.For.UmbracoSettings().Content.ImageFileTypes.InvariantContains(ext.TrimStart('.')) == false)
|
||||
private HttpResponseMessage GetResized(IMedia media, int width)
|
||||
{
|
||||
var imageProp = media.Properties[Constants.Conventions.Media.File];
|
||||
if (imageProp == null)
|
||||
{
|
||||
return Request.CreateResponse(HttpStatusCode.NotFound);
|
||||
return Request.CreateResponse( HttpStatusCode.NotFound );
|
||||
}
|
||||
|
||||
var thumbFilePath = imagePath.TrimEnd(ext) + "_" + suffix + ".jpg";
|
||||
var fullOrgPath = mediaFileSystem.GetFullPath(mediaFileSystem.GetRelativePath(imagePath));
|
||||
var fullNewPath = mediaFileSystem.GetFullPath(mediaFileSystem.GetRelativePath(thumbFilePath));
|
||||
var thumbIsNew = mediaFileSystem.FileExists(fullNewPath) == false;
|
||||
if (thumbIsNew)
|
||||
{
|
||||
//we need to generate it
|
||||
if (mediaFileSystem.FileExists(fullOrgPath) == false)
|
||||
{
|
||||
return Request.CreateResponse(HttpStatusCode.NotFound);
|
||||
}
|
||||
|
||||
using (var fileStream = mediaFileSystem.OpenFile(fullOrgPath))
|
||||
{
|
||||
if (fileStream.CanSeek) fileStream.Seek(0, 0);
|
||||
using (var originalImage = Image.FromStream(fileStream))
|
||||
{
|
||||
//If it is bigger, then do the resize
|
||||
if (originalImage.Width >= width && originalImage.Height >= width)
|
||||
{
|
||||
ImageHelper.GenerateThumbnail(
|
||||
originalImage,
|
||||
width,
|
||||
fullNewPath,
|
||||
"jpg",
|
||||
mediaFileSystem);
|
||||
}
|
||||
else
|
||||
{
|
||||
//just return the original image
|
||||
fullNewPath = fullOrgPath;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
var result = Request.CreateResponse(HttpStatusCode.OK);
|
||||
//NOTE: That we are not closing this stream as the framework will do that for us, if we try it will
|
||||
// fail. See http://stackoverflow.com/questions/9541351/returning-binary-file-from-controller-in-asp-net-web-api
|
||||
var stream = mediaFileSystem.OpenFile(fullNewPath);
|
||||
if (stream.CanSeek) stream.Seek(0, 0);
|
||||
result.Content = new StreamContent(stream);
|
||||
result.Headers.Date = mediaFileSystem.GetLastModified(imagePath);
|
||||
result.Content.Headers.ContentType = new MediaTypeHeaderValue("image/jpeg");
|
||||
return result;
|
||||
var imagePath = imageProp.Value.ToString();
|
||||
var response = Request.CreateResponse( HttpStatusCode.Found );
|
||||
response.Headers.Location = new Uri( string.Format( "{0}?rnd={1}&width={2}", imagePath, string.Format( "{0:yyyyMMddHHmmss}", media.UpdateDate ), width ), UriKind.Relative );
|
||||
return response;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user