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

de.jwic.controls.AbstractSelectListControl Maven / Gradle / Ivy

There is a newer version: 5.3.43
Show newest version
/*******************************************************************************
 * Copyright 2015 xWic group (http://www.xwic.de)
 *
 * Licensed 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.
 *  
 *******************************************************************************/
package de.jwic.controls;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import de.jwic.base.IControlContainer;
import de.jwic.data.DataLabel;
import de.jwic.data.ISelectElement;
import de.jwic.data.Range;
import de.jwic.data.SelectElement;
import de.jwic.data.SelectElementBaseLabelProvider;
import de.jwic.data.SelectElementContentProvider;

/**
 * This version of the AbstractListControl implements a simple list of ISelectElment's
 * so that child controls can use simple title:key elements.
 * 
 * @author lordsam
 */
public class AbstractSelectListControl extends AbstractListControl {

	protected List elements = null;

	/**
	 * @param container
	 * @param name
	 */
	public AbstractSelectListControl(IControlContainer container, String name) {
		super(container, name);
		baseLabelProvider = new SelectElementBaseLabelProvider();

		elements = new ArrayList();
		setContentProvider(new SelectElementContentProvider(elements));
	}

	/**
	 * Returns a list of ListEntry elements for rendering. It is faster to prepare the
	 * list this way than to do this in the velocity template.
	 * @return
	 */
	public List buildEntryList() {
		List allEntries = new ArrayList();
		for (Iterator it = contentProvider.getContentIterator(new Range()); it.hasNext() ; ) {
			ISelectElement elm = it.next();
			DataLabel label = baseLabelProvider.getBaseLabel(elm);
			String key = contentProvider.getUniqueKey(elm);
			allEntries.add(new ListEntry(label.text, key));
		}
		return allEntries;
	}

	/**
	 * Returns true if the given key is selected.
	 * @param key
	 * @return
	 */
	public boolean isKeySelected(String key) {
		if (key != null) {
			String[] keys = getSelectedKeys();
			if (keys != null) {
				for (String k : keys) {
					if (key.equals(k)) {
						return true;
					}
				}
			}
		} 
		return false;
	}

	/**
	 * Add an element.
	 * @param element
	 * @return true if element has been added, false if duplicate
	 */
	public boolean addElement(ISelectElement element) {
		boolean notContainsElement = true;
		if (element.getKey() != null) {
			if (contentProvider.getObjectFromKey(element.getKey()) != null) {
				notContainsElement = false;
				//throw new IllegalArgumentException("An element with the key '" + element.getKey() + "' does already exist in the selection.");
			}
		}
		
		if(notContainsElement){
			elements.add(element);
		}
		requireRedraw();
		
		return notContainsElement;
	}

	/**
	 * Add an element. The key will automatically be assigned.
	 * @param title
	 */
	public ISelectElement addElement(String title) {
		SelectElement elm = new SelectElement(title, title);
		addElement(elm);
		return elm;
	}

	/**
	 * Add the element with a custom key.
	 * @param title
	 * @param key
	 */
	public ISelectElement addElement(String title, String key) {
		SelectElement elm = new SelectElement(title, key);
		addElement(elm);
		return elm;
	}

	/**
	 * Remove an element.
	 * @param element
	 */
	public void removeElement(ISelectElement element) {
		String key = contentProvider.getUniqueKey(element);
		if (isKeySelected(key)) {
			clearSelection(key);
		}
		elements.remove(element);
		requireRedraw();
	}

	/**
	 * @param key
	 */
	public void clearSelection(String key) {
		if (key != null) {
			String[] values = valueField.getValues();
			String[] tmp = new String[values.length];
			int cnt = 0;
			for (int i = 0; i < values.length; i++) {
				if (!key.equals(values[i])) {
					tmp[cnt++] = values[i];
				}
			}
			if (cnt != values.length) { // an element was removed
				String[] newValues = new String[cnt];
				System.arraycopy(tmp, 0, newValues, 0, cnt);
				valueField.setValues(newValues);
			}
		}	
	}

	/**
	 * Remove an element by its key.
	 * @param key
	 */
	public void removeElementByKey(String key) {
		ISelectElement obj = contentProvider.getObjectFromKey(key);
		if (obj != null) {
			removeElement(obj);
		}
	}

	/**
	 * Select the element with the specified key. Works only with elements that 
	 * do have a key.
	 * @param key
	 */
	public void selectedByKey(String key) {
		if (key != null && elements != null) {
			for (ISelectElement se : elements) {
				if (key.equals(se.getKey())) {
					setSelectedElement(se);
					return;
				}
			}
		}
		setSelectedKey(null);
		requireRedraw();
	}

	/**
	 * 
	 */
	public void clear() {
		if(elements != null){
			elements.clear();
		}
		setSelectedElement(null);
		requireRedraw();
	}
	
	/**
	 * Returns elements as keyValuePair Map.
	 * @return
	 */
	public Map buildElementsMap(){
		Map result = new HashMap();
		for (ISelectElement element : elements) {
			result.put(element.getKey(), element);
		}
		
		return result;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy