summaryrefslogtreecommitdiffstats
path: root/uitest/src/com/vaadin/tests/TreeFilesystem.java
diff options
context:
space:
mode:
Diffstat (limited to 'uitest/src/com/vaadin/tests/TreeFilesystem.java')
-rw-r--r--uitest/src/com/vaadin/tests/TreeFilesystem.java120
1 files changed, 120 insertions, 0 deletions
diff --git a/uitest/src/com/vaadin/tests/TreeFilesystem.java b/uitest/src/com/vaadin/tests/TreeFilesystem.java
new file mode 100644
index 0000000000..f2a0d97b08
--- /dev/null
+++ b/uitest/src/com/vaadin/tests/TreeFilesystem.java
@@ -0,0 +1,120 @@
+/*
+ * Copyright 2011 Vaadin Ltd.
+ *
+ * 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.vaadin.tests;
+
+import java.io.File;
+
+import com.vaadin.data.Item;
+import com.vaadin.shared.ui.label.ContentMode;
+import com.vaadin.tests.util.SampleDirectory;
+import com.vaadin.ui.Label;
+import com.vaadin.ui.Panel;
+import com.vaadin.ui.UI.LegacyWindow;
+import com.vaadin.ui.Tree;
+import com.vaadin.ui.Tree.ExpandEvent;
+
+/**
+ * Browsable file explorer using Vaadin Tree component. Demonstrates: how to add
+ * items hierarchically into <code>com.vaadin.ui.Component.Tree</code>, how to
+ * receive ExpandEvent and implement
+ * <code>com.vaadin.ui.Tree.ExpandListener</code>.
+ *
+ * @since 4.0.0
+ *
+ */
+public class TreeFilesystem extends com.vaadin.Application.LegacyApplication
+ implements Tree.ExpandListener {
+
+ // Filesystem explorer panel and it's components
+ private final Panel explorerPanel = new Panel("Filesystem explorer");
+
+ private final Tree tree = new Tree();
+
+ @Override
+ public void init() {
+ final LegacyWindow main = new LegacyWindow("Tree filesystem demo");
+ setMainWindow(main);
+
+ // Main window contains heading and panel
+ main.addComponent(new Label("<h2>Tree demo</h2>", ContentMode.XHTML));
+
+ // configure file structure panel
+ main.addComponent(explorerPanel);
+ explorerPanel.addComponent(tree);
+ explorerPanel.setHeight("400px");
+
+ // "this" handles tree's expand event
+ tree.addListener(this);
+
+ // Get sample directory
+ final File sampleDir = SampleDirectory.getDirectory(this, main);
+ // populate tree's root node with example directory
+ if (sampleDir != null) {
+ populateNode(sampleDir.getAbsolutePath(), null);
+ }
+ }
+
+ /**
+ * Handle tree expand event, populate expanded node's childs with new files
+ * and directories.
+ */
+ @Override
+ public void nodeExpand(ExpandEvent event) {
+ final Item i = tree.getItem(event.getItemId());
+ if (!tree.hasChildren(i)) {
+ // populate tree's node which was expanded
+ populateNode(event.getItemId().toString(), event.getItemId());
+ }
+ }
+
+ /**
+ * Populates files to tree as items. In this example items are of String
+ * type that consist of file path. New items are added to tree and item's
+ * parent and children properties are updated.
+ *
+ * @param file
+ * path which contents are added to tree
+ * @param parent
+ * for added nodes, if null then new nodes are added to root node
+ */
+ private void populateNode(String file, Object parent) {
+ final File subdir = new File(file);
+ final File[] files = subdir.listFiles();
+ for (int x = 0; x < files.length; x++) {
+ try {
+ // add new item (String) to tree
+ final String path = files[x].getCanonicalPath().toString();
+ tree.addItem(path);
+ // set parent if this item has one
+ if (parent != null) {
+ tree.setParent(path, parent);
+ }
+ // check if item is a directory and read access exists
+ if (files[x].isDirectory() && files[x].canRead()) {
+ // yes, childrens therefore exists
+ tree.setChildrenAllowed(path, true);
+ } else {
+ // no, childrens therefore do not exists
+ tree.setChildrenAllowed(path, false);
+ }
+ } catch (final Exception e) {
+ throw new RuntimeException(e);
+ }
+ }
+ }
+
+}