mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
125788 rmunteanu: Merged 5.1.N (5.1.2) to 5.2.N (5.2.1) 125606 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2) 125515 slanglois: MNT-16155 Update source headers - add new Copyrights for Java and JSP source files + automatic check in the build git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@127810 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
256 lines
7.3 KiB
Java
256 lines
7.3 KiB
Java
/*
|
|
* #%L
|
|
* Alfresco Repository WAR Community
|
|
* %%
|
|
* Copyright (C) 2005 - 2016 Alfresco Software Limited
|
|
* %%
|
|
* This file is part of the Alfresco software.
|
|
* If the software was purchased under a paid Alfresco license, the terms of
|
|
* the paid license agreement will prevail. Otherwise, the software is
|
|
* provided under the following open source license terms:
|
|
*
|
|
* 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/>.
|
|
* #L%
|
|
*/
|
|
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 ConfigElement#getChildren()
|
|
*/
|
|
public List<ConfigElement> getChildren()
|
|
{
|
|
throw new ConfigException("Reading the sidebar config via the generic interfaces is not supported");
|
|
}
|
|
|
|
/**
|
|
* @see ConfigElement#combine(org.springframework.extensions.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();
|
|
}
|
|
}
|
|
}
|