All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.rdf4j.common.webapp.navigation.NavigationModel Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright (c) 2015 Eclipse RDF4J contributors, Aduna, and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Distribution License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *******************************************************************************/
package org.eclipse.rdf4j.common.webapp.navigation;

import java.util.ArrayList;
import java.util.List;

import org.eclipse.rdf4j.common.io.ResourceUtil;

/**
 * NavigationModel represents the navigation structure of a web application. A model consists of groups and
 * views.
 * 
 * @author Herko ter Horst
 */
public class NavigationModel extends Group {

	public static final String NAVIGATION_MODEL_KEY = "navigation-model";

	public static final String DEFAULT_PATH_PREFIX = "/";

	public static final String DEFAULT_PATH_SEPARATOR = "/";

	public static final String DEFAULT_VIEW_SUFFIX = ".view";

	public static final String DEFAULT_ICON_PREFIX = "/images/icons/";

	public static final String DEFAULT_ICON_SEPARATOR = "_";

	public static final String DEFAULT_ICON_SUFFIX = ".png";

	public static final String DEFAULT_I18N_PREFIX = "";

	public static final String DEFAULT_I18N_SEPARATOR = ".";

	public static final String DEFAULT_I18N_SUFFIX = ".title";

	private List navigationModelLocations = new ArrayList();

	private String pathPrefix;

	private String pathSeparator;

	private String iconPrefix;

	private String iconSeparator;

	private String iconSuffix;

	private String i18nPrefix;

	private String i18nSeparator;

	private String i18nSuffix;

	/**
	 * Construct a new, anonymous, empty NavigationModel
	 */
	public NavigationModel() {
		super(null);
	}

	/**
	 * Construct a new emtpy NavigationModel with the specified ID.
	 * 
	 * @param id
	 *        the ID of the NavigationModel
	 */
	public NavigationModel(String id) {
		super(id);
	}

	public String getId() {
		return "";
	}

	public String getPathPrefix() {
		if (pathPrefix == null) {
			setPathPrefix(DEFAULT_PATH_PREFIX);
		}
		return pathPrefix;
	}

	public void setPathPrefix(String pathPrefix) {
		this.pathPrefix = pathPrefix;
	}

	@Override
	public String getPathSeparator() {
		if (pathSeparator == null) {
			setPathSeparator(DEFAULT_PATH_SEPARATOR);
		}
		return pathSeparator;
	}

	public void setPathSeparator(String pathSeparator) {
		this.pathSeparator = pathSeparator;
	}

	@Override
	public String getIconPrefix() {
		if (iconPrefix == null) {
			setIconPrefix(DEFAULT_ICON_PREFIX);
		}
		return iconPrefix;
	}

	public void setIconPrefix(String iconPrefix) {
		this.iconPrefix = iconPrefix;
	}

	@Override
	public String getIconSeparator() {
		if (iconSeparator == null) {
			setIconSeparator(DEFAULT_ICON_SEPARATOR);
		}
		return iconSeparator;
	}

	public void setIconSeparator(String iconSeparator) {
		this.iconSeparator = iconSeparator;
	}

	@Override
	public String getIconSuffix() {
		if (iconSuffix == null) {
			setIconSuffix(DEFAULT_ICON_SUFFIX);
		}
		return iconSuffix;
	}

	public void setIconSuffix(String iconSuffix) {
		this.iconSuffix = iconSuffix;
	}

	public String getI18nPrefix() {
		if (i18nPrefix == null) {
			setI18nPrefix(DEFAULT_I18N_PREFIX);
		}
		return i18nPrefix;
	}

	public void setI18nPrefix(String i18nPrefix) {
		this.i18nPrefix = i18nPrefix;
	}

	@Override
	public String getI18nSeparator() {
		if (i18nSeparator == null) {
			setI18nSeparator(DEFAULT_I18N_SEPARATOR);
		}
		return i18nSeparator;
	}

	public void setI18nSeparator(String i18nSeparator) {
		this.i18nSeparator = i18nSeparator;
	}

	@Override
	public String getI18nSuffix() {
		if (i18nSuffix == null) {
			setI18nSuffix(DEFAULT_I18N_SUFFIX);
		}
		return i18nSuffix;
	}

	public void setI18nSuffix(String i18nSuffix) {
		this.i18nSuffix = i18nSuffix;
	}

	public String getViewSuffix() {
		if (viewSuffix == null) {
			setViewSuffix(DEFAULT_VIEW_SUFFIX);
		}
		return viewSuffix;
	}

	/**
	 * Find the view with the specified name in the NavigationModel.
	 * 
	 * @param viewName
	 *        the name of the view, specified as a /-separated hierarchy of groups, where the part after the
	 *        last / is interpreted as the name of the view itself.
	 * @return the view, or null if no view matching the specified name could be found
	 */
	public View findView(String viewName) {
		View result = null;

		int prefixLength = getPathPrefix().length();
		viewName = viewName.substring(prefixLength);
		result = findViewInternal(viewName);

		return result;
	}

	/**
	 * Add another NavigationModel to this one. This is done by adding all groups and view from the other
	 * model to this one.
	 * 
	 * @param other
	 *        the model to add to this one.
	 */
	public void addModel(NavigationModel other) {
		for (Group group : other.getGroups()) {
			addGroup(group);
		}
		for (View view : other.getViews()) {
			addView(view);
		}
	}

	/**
	 * Set the locations of the navigation model resources to be used in the construction of this model.
	 * Calling this method will cause this NavigationModel to be initialized.
	 * 
	 * @param navigationModelLocations
	 *        a list of resource names
	 */
	public void setNavigationModels(List navigationModelLocations) {
		this.navigationModelLocations = navigationModelLocations;
		createNavigationModel();
	}

	private void createNavigationModel() {
		boolean first = true;
		for (String navigationModelLocation : navigationModelLocations) {
			NavigationXmlParser parser = new NavigationXmlParser();
			if (first) {
				parser.parseInto(this, ResourceUtil.getURL(navigationModelLocation));
				first = false;
			}
			else {
				addModel(parser.parse(ResourceUtil.getURL(navigationModelLocation)));
			}
		}
	}

	public Object clone() {
		NavigationModel result = new NavigationModel(getId());
		copyCommonAttributes(result);
		copyGroupsAndViews(result);
		return result;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy