/* * Copyright (c) 2012 Data Harmonisation Panel * * All rights reserved. This program and the accompanying materials are made * available 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. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution. If not, see <http://www.gnu.org/licenses/>. * * Contributors: * HUMBOLDT EU Integrated Project #030962 * Data Harmonisation Panel <http://www.dhpanel.eu> */ package eu.esdihumboldt.hale.ui.views.tasks; import org.eclipse.jface.viewers.BaseLabelProvider; import org.eclipse.jface.viewers.TreeNode; import org.eclipse.swt.graphics.Image; import eu.esdihumboldt.hale.ui.util.tree.DefaultTreeNode; import eu.esdihumboldt.hale.ui.util.tree.MapTreeNode; import eu.esdihumboldt.hale.ui.util.tree.MultiColumnTreeNodeLabelProvider; import eu.esdihumboldt.hale.ui.views.tasks.internal.TasksViewPlugin; import eu.esdihumboldt.hale.ui.views.tasks.model.ResolvedTask; /** * Task description label provider * * @author Simon Templer * @partner 01 / Fraunhofer Institute for Computer Graphics Research */ public class TaskValueLabelProvider extends MultiColumnTreeNodeLabelProvider { private final Image priorityImage; private final int index; /** * Default constructor * * @param index index of the task value */ public TaskValueLabelProvider(int index) { super(index); this.index = index; priorityImage = TasksViewPlugin.getImageDescriptor("icons/priority.gif").createImage(); //$NON-NLS-1$ } /** * @see MultiColumnTreeNodeLabelProvider#getValueImage(Object, TreeNode) */ @Override protected Image getValueImage(Object value, TreeNode node) { if (value instanceof ResolvedTask) { ResolvedTask task = (ResolvedTask) value; if (task.isOpen()) { return getValueImage(task.getValue()); } else { return super.getValueImage(value, node); } } else if (node instanceof MapTreeNode<?, ?>) { return getNodeImage((MapTreeNode<?, ?>) node); } else { return super.getValueImage(value, node); } } /** * Get the image for the given value * * @param value the value * * @return the image or <code>null</code> */ private Image getValueImage(double value) { if (value > 0.5) { return priorityImage; } else { return null; } } /** * Get the image for the given node * * @param node the node * * @return the image or <code>null</code> */ private Image getNodeImage(MapTreeNode<?, ?> node) { double value = getNodeValue(node); return getValueImage(value); } /** * Get the given node's severity level * * @param node the node * * @return the severity level or <code>null</code> */ private double getNodeValue(MapTreeNode<?, ?> node) { double result = 0.0; TreeNode[] children = node.getChildren(); for (TreeNode child : children) { if (child instanceof DefaultTreeNode) { // child is task node DefaultTreeNode childNode = (DefaultTreeNode) child; Object tmp = childNode.getValue(); // get value Object value; if (tmp.getClass().isArray()) { value = ((Object[]) tmp)[index]; } else { value = tmp; } // determine level if (value instanceof ResolvedTask) { ResolvedTask task = (ResolvedTask) value; if (task.isOpen()) { result = Math.max(result, task.getValue()); } } } else if (child instanceof MapTreeNode<?, ?>) { // child is map node MapTreeNode<?, ?> childNode = (MapTreeNode<?, ?>) child; double childValue = getNodeValue(childNode); result = Math.max(result, childValue); } } return result; } /** * @see MultiColumnTreeNodeLabelProvider#getValueText(Object, TreeNode) */ @Override protected String getValueText(Object value, TreeNode node) { return ""; //$NON-NLS-1$ } /** * @see BaseLabelProvider#dispose() */ @Override public void dispose() { priorityImage.dispose(); super.dispose(); } }