/* * Copyright 2005 The Apache Software Foundation. * * 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 com.idega.content.tree; import java.util.List; import java.util.ArrayList; public class TreeNodeBase implements TreeNode, Comparable { private static final long serialVersionUID = 278589014441538822L; private List children = new ArrayList(); private String type; private String description; private boolean leaf; private String identifier; public TreeNodeBase() {} public TreeNodeBase(String type, String description, boolean leaf) { this(type, description, null, leaf); } public TreeNodeBase(String type, String description, String identifier, boolean leaf) { this.type = type; this.description = description; this.identifier = identifier; this.leaf = leaf; } public boolean isLeaf() { return leaf || (getChildCount() == 0); } public void setLeaf(boolean leaf) { this.leaf = leaf; } public List getChildren() { return children; } public String getType() { return type; } public void setType(String type) { this.type = type; } public void setDescription(String description) { this.description = description; } public String getDescription() { return description; } public void setIdentifier(String identifier) { this.identifier = identifier; } public String getIdentifier() { return identifier; } public int getChildCount() { return getChildren().size(); } public int compareTo(Object obj) { // branches come before leaves, after this criteria nodes are sorted alphabetically TreeNode otherNode = (TreeNode)obj; if (isLeaf() && !otherNode.isLeaf()) { // leaves come after branches return 1; } else if (!isLeaf() && otherNode.isLeaf()) { // branches come before leaves return -1; } else { // both nodes are leaves or both node are branches, so compare the descriptions return getDescription().compareTo(otherNode.getDescription()); } } }