blob: e14268bbd4873a6d05be5c1c73398d848dc24547 [file] [log] [blame]
/*
* $Id$
* $Revision$ $Date$
*
* ==============================================================================
* 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 wicket.examples.nested;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeModel;
import javax.swing.tree.TreeModel;
import javax.swing.tree.TreeNode;
import wicket.PageParameters;
import wicket.examples.WicketExamplePage;
import wicket.examples.ajax.builtin.tree.SimpleTreePage;
import wicket.markup.html.link.BookmarkablePageLink;
import wicket.markup.html.link.Link;
import wicket.markup.html.tree.Tree;
import wicket.markup.html.tree.DefaultAbstractTree.LinkType;
/**
* Examples that shows how you can display a tree like structure (in this case
* nested lists with string elements) using nested panels and using a tree
* component.
*
* @author Eelco Hillenius
*/
public class Home extends WicketExamplePage
{
/**
* Constructor.
*
* @param parameters
* Page parameters
*/
public Home(final PageParameters parameters)
{
// create a list with sublists
List<Object> l1 = new ArrayList<Object>();
l1.add("test 1.1");
l1.add("test 1.2");
List<Object> l2 = new ArrayList<Object>();
l2.add("test 2.1");
l2.add("test 2.2");
l2.add("test 2.3");
List<String> l3 = new ArrayList<String>();
l3.add("test 3.1");
l2.add(l3);
l2.add("test 2.4");
l1.add(l2);
l1.add("test 1.3");
// construct the panel
new RecursivePanel(this, "panels", l1);
// create a tree
TreeModel treeModel = convertToTreeModel(l1);
final Tree tree = new Tree(this, "tree", treeModel)
{
/**
* @see wicket.markup.html.tree.Tree#renderNode(javax.swing.tree.TreeNode)
*/
@Override
protected String renderNode(TreeNode node)
{
return node.isLeaf() ? node.toString() : "<sub>";
}
};
tree.setLinkType(LinkType.REGULAR);
new Link(this, "expandAll")
{
@Override
public void onClick()
{
tree.getTreeState().expandAll();
}
};
new Link(this, "collapseAll")
{
@Override
public void onClick()
{
tree.getTreeState().collapseAll();
}
};
new BookmarkablePageLink(this, "ajaxTreeLink", SimpleTreePage.class);
}
/**
* Add a sublist to the parent.
*
* @param parent
* the parent
* @param sub
* the sub list
*/
private void add(final DefaultMutableTreeNode parent, final List sub)
{
for (Iterator i = sub.iterator(); i.hasNext();)
{
Object o = i.next();
if (o instanceof List)
{
DefaultMutableTreeNode child = new DefaultMutableTreeNode(o);
parent.add(child);
add(child, (List)o);
}
else
{
DefaultMutableTreeNode child = new DefaultMutableTreeNode(o);
parent.add(child);
}
}
}
/**
* Convert the nested lists to a tree model
*
* @param list
* the list
* @return tree model
*/
private TreeModel convertToTreeModel(final List list)
{
TreeModel model = null;
DefaultMutableTreeNode rootNode = new DefaultMutableTreeNode("ROOT");
add(rootNode, list);
model = new DefaultTreeModel(rootNode);
return model;
}
}