cmspicturebrowser.java
来自「java 编写的程序」· Java 代码 · 共 427 行 · 第 1/2 页
JAVA
427 行
/*
* File : $Source: /usr/local/cvs/opencms/src/com/opencms/workplace/CmsPictureBrowser.java,v $
* Date : $Date: 2002/04/05 13:15:00 $
* Version: $Revision: 1.32 $
*
* This library is part of OpenCms -
* the Open Source Content Mananagement System
*
* Copyright (C) 2001 The OpenCms Group
*
* This library 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 2.1 of the License, or (at your option) any later version.
*
* This library 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.
*
* For further information about OpenCms, please see the
* OpenCms Website: http://www.opencms.org
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package com.opencms.workplace;
import com.opencms.file.*;
import com.opencms.core.*;
import com.opencms.util.*;
import com.opencms.template.*;
import java.util.*;
import javax.servlet.http.*;
/**
* Template class for displaying OpenCms picture browser.
* <P>
* Reads template files of the content type <code>CmsXmlWpTemplateFile</code>.
*
* @author Alexander Lucas
* @author Mario Stanke
* @version $Revision: 1.32 $ $Date: 2002/04/05 13:15:00 $
* @see com.opencms.workplace.CmsXmlWpTemplateFile
*/
public class CmsPictureBrowser extends CmsWorkplaceDefault {
/**
* Gets the content of a defined section in a given template file and its subtemplates
* with the given parameters.
*
* @see getContent(CmsObject cms, String templateFile, String elementName, Hashtable parameters)
* @param cms CmsObject Object for accessing system resources.
* @param templateFile Filename of the template file.
* @param elementName Element name of this template in our parent template.
* @param parameters Hashtable with all template class parameters.
* @param templateSelector template section that should be processed.
*/
public byte[] getContent(CmsObject cms, String templateFile, String elementName, Hashtable parameters, String templateSelector) throws CmsException {
if(I_CmsLogChannels.C_PREPROCESSOR_IS_LOGGING && A_OpenCms.isLogging() && C_DEBUG) {
A_OpenCms.log(C_OPENCMS_DEBUG, getClassName() + "getting content of element "
+ ((elementName == null) ? "<root>" : elementName));
A_OpenCms.log(C_OPENCMS_DEBUG, getClassName()
+ "template file is: " + templateFile);
A_OpenCms.log(C_OPENCMS_DEBUG, getClassName()
+ "selected template section is: " + ((templateSelector == null) ? "<default>" : templateSelector));
}
I_CmsSession session = cms.getRequestContext().getSession(true);
CmsXmlWpTemplateFile xmlTemplateDocument = (CmsXmlWpTemplateFile)getOwnTemplateFile(cms,
templateFile, elementName, parameters, templateSelector);
// test whether the pics folder exists at all
try {
cms.readFileHeader(getConfigFile(cms).getPicGalleryPath());
}
catch(CmsException e) {
xmlTemplateDocument.setData("ERRORDETAILS", Utils.getStackTrace(e));
templateSelector = "error";
}
if(!"error".equals(templateSelector)) {
if(parameters.get(C_PARA_INITIAL) != null) {
session.removeValue(C_PARA_FOLDER);
session.removeValue("picBrowser_for_ext_nav");
}
String setOnClick = (String)parameters.get("setonclick");
if(setOnClick != null){
session.putValue("picBrowser_for_ext_nav", setOnClick);
}
setOnClick = (String)session.getValue("picBrowser_for_ext_nav");
String folder = (String)parameters.get(C_PARA_FOLDER);
if(folder != null) {
session.putValue(C_PARA_FOLDER, folder);
}
folder = (String)session.getValue(C_PARA_FOLDER);
if(folder == null || "".equals(folder)) {
folder = getConfigFile(cms).getPicGalleryPath();
Vector galleries = cms.getSubFolders(folder);
if(galleries.size() > 0) {
// take the first gallery
folder = ((CmsResource)galleries.elementAt(0)).getAbsolutePath();
session.putValue(C_PARA_FOLDER, folder);
}
else {
// there was a /pics/ - folder but no galery in it
templateSelector = "error_no_gallery";
}
}
if(!"error_no_gallery".equals(templateSelector)) {
String pageText = (String)parameters.get(C_PARA_PAGE);
String filter = (String)parameters.get(C_PARA_FILTER);
// Check if the user requested a special page
if(pageText == null || "".equals(pageText)) {
pageText = "1";
parameters.put(C_PARA_PAGE, pageText);
}
// Check if the user requested a filter
if(filter == null) {
filter = "";
parameters.put(C_PARA_FILTER, filter);
}
// Compute the maximum page number
Vector filteredPics = getFilteredPicList(cms, folder, filter);
int maxpage = ((filteredPics.size() - 1) / C_PICBROWSER_MAXIMAGES) + 1;
// Now set the appropriate datablocks
xmlTemplateDocument.setData(C_PARA_FOLDER, Encoder.escape(folder));
xmlTemplateDocument.setData(C_PARA_PAGE, pageText);
xmlTemplateDocument.setData(C_PARA_FILTER, filter);
xmlTemplateDocument.setData(C_PARA_MAXPAGE, "" + maxpage);
if(setOnClick == null || !"true".equals(setOnClick)){
xmlTemplateDocument.setData("setonclick", "");
}else{
xmlTemplateDocument.setData("setonclick", "true");
}
parameters.put("_PICLIST_", filteredPics);
}
}
// Start the processing
return startProcessing(cms, xmlTemplateDocument, elementName, parameters, templateSelector);
}
/**
* Internal method for getting a vector of all pictures using
* a given filter.
* @param cms Cms object for accessing system resources.
* @param folder Folder to look for pictures.
* @param filter Search pattern that should be used.
* @return Vector of CmsFile objects.
*/
private Vector getFilteredPicList(CmsObject cms, String folder, String filter) throws CmsException {
// Get all pictures in the given folder using the cms object
Vector allPics = cms.getFilesInFolder(folder);
// Filter the pics
Vector filteredPics = new Vector();
for(int i = 0;i < allPics.size();i++) {
CmsFile file = (CmsFile)allPics.elementAt(i);
String filename = file.getName();
String title = cms.readProperty(file.getAbsolutePath(), C_PROPERTY_TITLE);
boolean filenameFilter = inFilter(filename, filter);
boolean titleFilter = ((title == null) || ("".equals(title))) ? false : inFilter(title, filter);
if((filenameFilter || titleFilter) && isImage(filename)) {
filteredPics.addElement(file);
}
}
return filteredPics;
}
/**
* Gets the filenames of all picture galleries
* <P>
* The given vectors <code>names</code> and <code>values</code> will
* be filled with the appropriate information to be used for building
* a select box. The values will be the paths to the galleries.
*
* @param cms CmsObject Object for accessing system resources.
* @param names Vector to be filled with the appropriate values in this method.
* @param values Vector to be filled with the appropriate values in this method.
* @param parameters Hashtable containing all user parameters <em>(not used here)</em>.
* @return Index of the selected Gallery
* @exception CmsException
*/
public Integer getPicGalleryNames(CmsObject cms, CmsXmlLanguageFile lang,
Vector names, Vector values, Hashtable parameters) throws CmsException {
int ret = -1;
I_CmsSession session = cms.getRequestContext().getSession(true);
// which folder is the gallery?
String chosenFolder = (String)parameters.get(C_PARA_FOLDER);
if(chosenFolder == null) {
chosenFolder = (String)session.getValue(C_PARA_FOLDER);
}
if(chosenFolder == null) {
chosenFolder = "";
}
Vector folders = cms.getSubFolders(getConfigFile(cms).getPicGalleryPath());
int numFolders = folders.size();
for(int i = 0;i < numFolders;i++) {
CmsResource currFolder = (CmsResource)folders.elementAt(i);
String name = currFolder.getName();
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?