Files
alfresco-community-repo/source/java/org/alfresco/web/config/SidebarConfigElement.java
Kevin Roast 0c88b471ee Merged DEV/TEMPORARY to HEAD
17667: Branch for SpringSurf integration - from HEAD r17665
   17668: Fix to ensure included scripts files are not loaded from a cached classpath loader.
   17670: Part 1 of SpringSurf integration - changes relating to spring-surf-core-1.0.0.CI-SNAPSHOT.jar
   17674: Part 2 of SpringSurf integration - changes relating to spring-surf-core-configservice-1.0.0.CI-SNAPSHOT.jar

git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@17788 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2009-12-14 13:41:05 +00:00

255 lines
7.5 KiB
Java

/*
* Copyright (C) 2005-2007 Alfresco Software Limited.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program 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 General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* As a special exception to the terms and conditions of version 2.0 of
* the GPL, you may redistribute this Program in connection with Free/Libre
* and Open Source Software ("FLOSS") applications as described in Alfresco's
* FLOSS exception. You should have recieved a copy of the text describing
* the FLOSS exception, and it is also available here:
* http://www.alfresco.com/legal/licensing"
*/
package org.alfresco.web.config;
import java.io.Serializable;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import org.springframework.extensions.config.ConfigElement;
import org.springframework.extensions.config.ConfigException;
import org.springframework.extensions.config.element.ConfigElementAdapter;
import org.springframework.extensions.surf.util.ParameterCheck;
/**
* Custom config element that represents the config data for the sidebar
*
* @author gavinc
*/
public class SidebarConfigElement extends ConfigElementAdapter implements Serializable
{
private static final long serialVersionUID = -251308123183340915L;
public static final String CONFIG_ELEMENT_ID = "sidebar";
private String defaultPlugin;
private Map<String, SidebarPluginConfig> plugins = new LinkedHashMap<String, SidebarPluginConfig>(8, 10f);
/**
* Default constructor
*/
public SidebarConfigElement()
{
super(CONFIG_ELEMENT_ID);
}
/**
* Constructor
*
* @param name Name of the element this config element represents
*/
public SidebarConfigElement(String name)
{
super(name);
}
/**
* @see org.alfresco.config.ConfigElement#getChildren()
*/
public List<ConfigElement> getChildren()
{
throw new ConfigException("Reading the sidebar config via the generic interfaces is not supported");
}
/**
* @see org.alfresco.config.ConfigElement#combine(org.alfresco.config.ConfigElement)
*/
public ConfigElement combine(ConfigElement configElement)
{
SidebarConfigElement newElement = (SidebarConfigElement)configElement;
SidebarConfigElement combinedElement = new SidebarConfigElement();
// add all the plugins from this element
for (SidebarPluginConfig plugin : this.getPlugins().values())
{
combinedElement.addPlugin(plugin);
}
// add all the plugins from the given element
for (SidebarPluginConfig plugin : newElement.getPlugins().values())
{
combinedElement.addPlugin(plugin);
}
// work out the default plugin
String newDefaultPlugin = newElement.getDefaultPlugin();
if (newDefaultPlugin != null)
{
combinedElement.setDefaultPlugin(newDefaultPlugin);
}
else
{
combinedElement.setDefaultPlugin(this.getDefaultPlugin());
}
return combinedElement;
}
/**
* Returns the named plugin
*
* @param id The id of the plugin to retrieve
* @return The SidebarPluginConfig object for the requested plugin or null if it doesn't exist
*/
public SidebarPluginConfig getPlugin(String id)
{
return this.plugins.get(id);
}
/**
* @return Returns a map of the plugins. A linked hash map is used internally to
* preserve ordering.
*/
public Map<String, SidebarPluginConfig> getPlugins()
{
return this.plugins;
}
/**
* @return The id of the default plugin, null if there isn't a default defined
*/
public String getDefaultPlugin()
{
return this.defaultPlugin;
}
/**
* Sets the plugin to use as the default
*
* @param defaultPlugin Id of the default plugin
*/
public void setDefaultPlugin(String defaultPlugin)
{
this.defaultPlugin = defaultPlugin;
}
/**
* Adds a plugin
*
* @param pluginConfig A pre-configured plugin config object
*/
/*package*/ void addPlugin(SidebarPluginConfig pluginConfig)
{
this.plugins.put(pluginConfig.getId(), pluginConfig);
}
/**
* Inner class representing the configuration of a sidebar plugin
*
* @author gavinc
*/
public static class SidebarPluginConfig implements Serializable
{
private static final long serialVersionUID = 1400852211128756652L;
protected String id;
protected String page;
protected String actionsConfigId;
protected String icon;
protected String label;
protected String labelId;
protected String description;
protected String descriptionId;
public SidebarPluginConfig(String id, String page,
String label, String labelId,
String description, String descriptionId,
String actionsConfigId, String icon)
{
// check the mandatory parameters are present
ParameterCheck.mandatoryString("id", id);
ParameterCheck.mandatoryString("page", page);
this.id = id;
this.page = page;
this.icon = icon;
this.label = label;
this.labelId = labelId;
this.description = description;
this.descriptionId = descriptionId;
this.actionsConfigId = actionsConfigId;
}
public String getId()
{
return this.id;
}
public String getPage()
{
return this.page;
}
public String getIcon()
{
return this.icon;
}
public String getlabel()
{
return this.label;
}
public String getlabelId()
{
return this.labelId;
}
public String getDescription()
{
return this.description;
}
public String getDescriptionId()
{
return this.descriptionId;
}
public String getActionsConfigId()
{
return this.actionsConfigId;
}
/**
* @see java.lang.Object#toString()
*/
@Override
public String toString()
{
StringBuilder buffer = new StringBuilder(super.toString());
buffer.append(" (id=").append(this.id);
buffer.append(" page=").append(this.page);
buffer.append(" icon=").append(this.icon);
buffer.append(" label=").append(this.label);
buffer.append(" labelId=").append(this.labelId);
buffer.append(" description=").append(this.description);
buffer.append(" descriptionId=").append(this.descriptionId);
buffer.append(" actions-config-id=").append(this.actionsConfigId).append(")");
return buffer.toString();
}
}
}