blob: 399d39ddbf86fbe641cfc236a36de3d5675199bc [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. The ASF licenses this file to You
* under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License. For additional information regarding
* copyright in this work, please see the NOTICE file in the top level
* directory of this distribution.
*/
package org.apache.roller.weblogger.ui.struts2.editor;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.roller.weblogger.business.FileIOException;
import org.apache.roller.weblogger.business.MediaFileManager;
import org.apache.roller.weblogger.business.WebloggerFactory;
import org.apache.roller.weblogger.pojos.MediaFile;
import org.apache.roller.weblogger.pojos.MediaFileComparator;
import org.apache.roller.weblogger.pojos.MediaFileComparator.MediaFileComparatorType;
import org.apache.roller.weblogger.pojos.MediaFileDirectory;
import org.apache.roller.weblogger.pojos.MediaFileDirectoryComparator;
import org.apache.roller.weblogger.pojos.MediaFileDirectoryComparator.DirectoryComparatorType;
import org.apache.roller.weblogger.pojos.WeblogPermission;
import org.apache.roller.weblogger.ui.struts2.util.KeyValueObject;
import org.apache.struts2.convention.annotation.AllowedMethods;
import org.apache.struts2.interceptor.validation.SkipValidation;
/**
* Browse media files action.
*/
@SuppressWarnings("serial")
// TODO: make this work @AllowedMethods({"execute"})
public class MediaFileImageChooser extends MediaFileBase {
private static Log log = LogFactory.getLog(MediaFileImageChooser.class);
private String directoryId;
private String directoryName;
private List<MediaFile> childFiles;
private MediaFileDirectory currentDirectory;
public MediaFileImageChooser() {
this.actionName = "mediaFileImageChooser";
this.desiredMenu = "editor";
this.pageTitle = "mediaFileImaegChooser.title";
}
/**
* Prepares view action
*/
public void myPrepare() {
refreshAllDirectories();
}
@Override
public List<String> requiredWeblogPermissionActions() {
return Collections.singletonList(WeblogPermission.EDIT_DRAFT);
}
/**
* Fetches and displays list of media file for the given directory. The
* directory could be chosen by ID or path.
*
* @return String The result of the action.
*/
@SkipValidation
public String execute() {
MediaFileManager manager = WebloggerFactory.getWeblogger().getMediaFileManager();
try {
MediaFileDirectory directory;
if (this.directoryId != null) {
directory = manager.getMediaFileDirectory(this.directoryId);
} else if (this.directoryName != null) {
directory = manager.getMediaFileDirectoryByName(getActionWeblog(), this.directoryName);
this.directoryId = directory.getId();
} else {
directory = manager.getDefaultMediaFileDirectory(getActionWeblog());
this.directoryId = directory.getId();
}
this.childFiles = new ArrayList<>();
this.childFiles.addAll(directory.getMediaFiles());
this.childFiles.sort(new MediaFileComparator( MediaFileComparatorType.NAME));
this.currentDirectory = directory;
// List of available directories
List<MediaFileDirectory> sortedDirList = new ArrayList<>();
List<MediaFileDirectory> directories = manager.getMediaFileDirectories(getActionWeblog());
for (MediaFileDirectory mediaFileDirectory : directories) {
if (!"default".equals(mediaFileDirectory.getName()) || !"default".equals(directory.getName())) {
sortedDirList.add(mediaFileDirectory);
}
}
sortedDirList.sort(new MediaFileDirectoryComparator(
DirectoryComparatorType.NAME));
setAllDirectories(sortedDirList);
return SUCCESS;
} catch (Exception ex) {
log.error("Error viewing media file directory ", ex);
addError("MediaFile.error.view");
}
return SUCCESS;
}
/**
* Returns the hierarchy of the current directory. This is useful in
* displaying path information as breadcrumb.
*/
public List<KeyValueObject> getCurrentDirectoryHierarchy() {
List<KeyValueObject> directoryHierarchy = new ArrayList<KeyValueObject>();
String fullPath = "/" + this.currentDirectory.getName();
if (fullPath.length() > 1) {
String[] directoryNames = fullPath.substring(1).split("/");
String dirPath = "";
for (String directoryName : directoryNames) {
dirPath = dirPath + "/" + directoryName;
directoryHierarchy.add(new KeyValueObject(dirPath,
directoryName));
}
}
return directoryHierarchy;
}
/**
* @return the directoryId
*/
public String getDirectoryId() {
return directoryId;
}
/**
* @param directoryId
* the directoryId to set
*/
public void setDirectoryId(String directoryId) {
this.directoryId = directoryId;
}
/**
* @return the directory name
*/
public String getDirectoryName() {
return directoryName;
}
/**
* @param directoryName
* the directoryName to set
*/
public void setDirectoryName(String directoryName) {
this.directoryName = directoryName;
}
/**
* @return the childFiles
*/
public List<MediaFile> getChildFiles() {
return childFiles;
}
/**
* @param childFiles
* the childFiles to set
*/
public void setChildFiles(List<MediaFile> childFiles) {
this.childFiles = childFiles;
}
/**
* @return the currentDirectory
*/
public MediaFileDirectory getCurrentDirectory() {
return currentDirectory;
}
/**
* @param currentDirectory
* the currentDirectory to set
*/
public void setCurrentDirectory(MediaFileDirectory currentDirectory) {
this.currentDirectory = currentDirectory;
}
}