mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
99981: Merged 5.0.N (5.0.2) to HEAD-BUG-FIX (5.1/Cloud) (PARTIAL MERGE) 99482: Merged DEV to 5.0.N (5.0.1) 99198 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc typo in project alfresco-jlan 99413 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project alfresco-jlan 99205 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project core 99415 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project data-model 99227 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project file-transfer-receiver 99416 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project legacy-lucene 99417 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project qa-share 99418 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project remote-api 99427 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc in project Repository, letters S..Z 99433 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc in project Repository, letters A..R 99421 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project share-po 99247 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc typo in project slingshot 99248 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project slingshot 99424 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project solr 99426 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project solr4 99253 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project solr-client 99259 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project web-client 99260 : MNT-13545: JavaDoc : Inconsistencies between the Java doc and the actual code - Changed Javadoc parameters inconsistence in project web-framework-commons git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@100501 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
148 lines
5.7 KiB
Java
148 lines
5.7 KiB
Java
/*
|
|
* Copyright (C) 2005-2010 Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco 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 Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
package org.alfresco.repo.thumbnail.script;
|
|
|
|
import java.text.MessageFormat;
|
|
import java.util.Map;
|
|
|
|
import org.alfresco.repo.jscript.BaseScopableProcessorExtension;
|
|
import org.alfresco.repo.thumbnail.ThumbnailDefinition;
|
|
import org.alfresco.service.ServiceRegistry;
|
|
|
|
|
|
/**
|
|
* Script object representing the site service.
|
|
*
|
|
* @author Roy Wetherall
|
|
*/
|
|
public class ScriptThumbnailService extends BaseScopableProcessorExtension
|
|
{
|
|
/** Service Registry */
|
|
private ServiceRegistry serviceRegistry;
|
|
|
|
/**
|
|
* Sets the Service Registry
|
|
*
|
|
* @param serviceRegistry
|
|
*/
|
|
public void setServiceRegistry(ServiceRegistry serviceRegistry)
|
|
{
|
|
this.serviceRegistry = serviceRegistry;
|
|
}
|
|
|
|
/**
|
|
* Indicates whether a given thumbnail name has been registered.
|
|
*
|
|
* @param thumbnailName thumbnail name
|
|
* @return boolean true if the thumbnail name is registered, false otherwise
|
|
*/
|
|
public boolean isThumbnailNameRegistered(String thumbnailName)
|
|
{
|
|
return (this.serviceRegistry.getThumbnailService().getThumbnailRegistry().getThumbnailDefinition(thumbnailName) != null);
|
|
}
|
|
|
|
/**
|
|
* Gets the resource path for the place holder thumbnail for the given named thumbnail.
|
|
*
|
|
* Returns null if none set.
|
|
*
|
|
* @param thumbnailName the thumbnail name
|
|
* @return String the place holder thumbnail resource path, null if none set
|
|
*/
|
|
public String getPlaceHolderResourcePath(String thumbnailName)
|
|
{
|
|
String result = null;
|
|
ThumbnailDefinition details = this.serviceRegistry.getThumbnailService().getThumbnailRegistry().getThumbnailDefinition(thumbnailName);
|
|
if (details != null)
|
|
{
|
|
result = details.getPlaceHolderResourcePath();
|
|
}
|
|
return result;
|
|
}
|
|
|
|
/**
|
|
* Gets the resource path for the place holder thumbnail for the given named thumbnail and the given mime type.
|
|
* If there is no icon available for the specified MIME type, a generic icon will be used instead.
|
|
* The generic icon is that returned by {@link #getPlaceHolderResourcePath(String)}
|
|
* If neither a MIME-specific icon nor a generic icon is available, <code>null</code> is returned.
|
|
*
|
|
* @param thumbnailName the thumbnail name
|
|
* @param mimetype the mimetype of the piece of content.
|
|
* @return String the place holder thumbnail resource path
|
|
* @see #getPlaceHolderResourcePath(String)
|
|
*/
|
|
public String getMimeAwarePlaceHolderResourcePath(String thumbnailName, String mimetype)
|
|
{
|
|
String result = null;
|
|
|
|
// Sanity check
|
|
if (mimetype == null || mimetype.trim().length() == 0)
|
|
{
|
|
return getPlaceHolderResourcePath(thumbnailName);
|
|
}
|
|
|
|
Map<String, String> extensionsByMimetype = serviceRegistry.getMimetypeService().getExtensionsByMimetype();
|
|
// We get the extension for the mime type directly from the Map as we need
|
|
// to know if a mimetype is not recognised by the system. (The MimetypeService gives us ".bin"
|
|
// for unrecognised mimetypes.)
|
|
|
|
// The mime fragment is the part of the resource path that refers to the mime type
|
|
// e.g. "_pdf" in alfresco/thumbnail/thumbnail_placeholder_doclib_pdf.png
|
|
|
|
String extension = extensionsByMimetype.get(mimetype);
|
|
|
|
if (extension != null)
|
|
{
|
|
StringBuilder sb = new StringBuilder();
|
|
sb.append("_").append(String.valueOf(extension));
|
|
String mimeFragment = sb.toString();
|
|
|
|
ThumbnailDefinition details = serviceRegistry.getThumbnailService().getThumbnailRegistry().getThumbnailDefinition(thumbnailName);
|
|
if (details != null)
|
|
{
|
|
String resourcePath = details.getMimeAwarePlaceHolderResourcePath();
|
|
if (resourcePath != null)
|
|
{
|
|
// It's possible that the mimetype service recognises mime types for which we have no icon.
|
|
String formattedResourcePath = MessageFormat.format(resourcePath, mimeFragment);
|
|
boolean iconResourceExists = classpathResourceExists("/" + formattedResourcePath);
|
|
|
|
if (iconResourceExists)
|
|
{
|
|
result = formattedResourcePath;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return result == null ? getPlaceHolderResourcePath(thumbnailName) : result;
|
|
}
|
|
|
|
/**
|
|
* This method returns <code>true</code> if the specified classpath resource exists,
|
|
* else <code>false</code>.
|
|
*/
|
|
private boolean classpathResourceExists(String resourcePath)
|
|
{
|
|
boolean result = this.getClass().getResource(resourcePath) != null;
|
|
|
|
return result;
|
|
}
|
|
}
|