रिचफेसेस - रिच ट्री
इस अध्याय में, हम रिचफेसेस में ट्री प्रोसेसिंग के बारे में जानेंगे। रिचफेसेस एक पेड़ बनाने और हेरफेर करने के लिए सभी आवश्यक घटक प्रदान करते हैं।
<अमीर: treeNode>
इस टैग का उपयोग एक पदानुक्रमित पेड़ बनाने के लिए किया जाता है। प्रत्येक ट्री <ट्रीएनोड> के अंदर प्रदान किया गया नोड ट्री का एक बच्चा नोड होगा। इस टैग का उपयोग एक अन्य टैग के साथ किया जाएगा जिसे <अमीर: पेड़> कहा जाता है। वृक्ष बनाने के लिए हम जो भी उदाहरण चर का उपयोग कर रहे हैं, उन्हें इन तीनों में से किसी एक को लागू करना होगा -org.richfaces.model.TreeNode, org.richfaces.model.TreeDataModel, तथा javax.swing.tree.TreeNode।
निम्नलिखित उदाहरण में, हम बैकेंड से <समृद्ध: ट्रीनोड> टैग का उपयोग करके एक पेड़ को आबाद करेंगे।
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>TreeNode Example</title>
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
</h:head>
<h:body>
<h:form>
<rich:tree value = "#{tree.populateNode}" var = "tree">
<rich:treeNode>
<rich:treeModelRecursiveAdaptor>
</rich:treeModelRecursiveAdaptor>
<h:outputText value = "#{tree.data}" />
</rich:treeNode>
</rich:tree>
</h:form>
</h:body>
</html>
इसके बाद संबंधित जावा वर्ग लागू होता है “TreeNodeImpl” इंटरफेस।
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
import org.richfaces.model.TreeNodeImpl;
@ManagedBean
@RequestScoped
public class Tree extends TreeNodeImpl {
private Tree stationRoot;
private Tree populateNode;
private Object data;
public Tree() {
super();
}
public Tree(boolean leaf, Object data) {
super(leaf);
this.data = data;
}
public Object getData() {
return data;
}
public Tree getPopulateNode() {
if (populateNode == null) {
String[] List_OF_Node = {
"Frist Node", "Second Node", "Third Node", "Fourth Node", "Fifth Node"};
stationRoot = new Tree(false, "Example Of Tree");
for (int i = 0; i < List_OF_Node.length; i++) {
Tree child = new Tree(true, List_OF_Node[i]);
stationRoot.addChild(i, child);
}
populateNode = new Tree();
populateNode.addChild(0, stationRoot);
}
return populateNode;
}
}
कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट का उत्पादन करेगा।
<अमीर: treeModelAdaptor>
यह घटक एक मानचित्र को इनपुट के रूप में लेता है, इसके माध्यम से पुनरावृत्त करता है, और ब्राउज़र में आवश्यक आउटपुट उत्पन्न करता है। जब भी हमें एक पुनरावर्ती मानचित्र को पॉप्युलेट करने की आवश्यकता होती है, हम किसी अन्य टैग का उपयोग कर सकते हैं<rich:recursiveTreeModelAdaptor>।
निम्न उदाहरण दिखाता है कि ब्राउज़र में प्रोजेक्ट संरचना को कैसे प्रस्तुत किया जाए। RichFaces 3 में, इन दो टैग्स का उपयोग किया जाता है <अमीर: treeNodeAdaptor> और <rich: recursiveTreeNodeAdaptor>।
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Tree Model and Recursive Model Example</title>
</h:head>
<h:body>
<h:form id = "form">
<rich:tree toggleType = "AJAX" var = "item" style = "max-width: 400px">
<rich:treeModelRecursiveAdaptor roots = "#{fileSystemBean.sourceRoots}"
nodes = "#{item.directories}">
<rich:treeNode>
#{item.shortPath}
</rich:treeNode>
<rich:treeModelAdaptor nodes = "#{item.files}">
<rich:treeNode>#{item}</rich:treeNode>
</rich:treeModelAdaptor>
</rich:treeModelRecursiveAdaptor>
</rich:tree>
</h:form>
</h:body>
</html>
हमें इस उदाहरण के लिए दो नए जावा बीन्स बनाने की आवश्यकता है। सेम क्लास "FileSystemBean.java" के लिए कोड स्निपेट निम्नलिखित है, जो आवश्यक फ़ोल्डर नाम रखता है।
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class FileSystemBean {
private static final String SRC_PATH = "/WEB-INF";
private List<FileSystemNode> srcRoots;
public synchronized List<FileSystemNode> getSourceRoots() {
if (srcRoots == null) {
srcRoots = new FileSystemNode(SRC_PATH).getDirectories();
}
return srcRoots;
}
}
सेम क्लास "FileSystemNode.java" के लिए कोड स्निपेट निम्नलिखित है, जो परियोजना की आवश्यक पत्ती नोड रखता है।
import static com.google.common.base.Predicates.containsPattern;
import static com.google.common.base.Predicates.not;
import static com.google.common.collect.Iterables.filter;
import static com.google.common.collect.Iterables.transform;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Set;
import javax.faces.context.ExternalContext;
import javax.faces.context.FacesContext;
import com.google.common.base.Function;
import com.google.common.collect.Iterables;
import com.google.common.collect.Lists;
public class FileSystemNode {
private static final Function<String, FileSystemNode>
FACTORY = new Function<String, FileSystemNode>() {
public FileSystemNode apply(String from) {
return new FileSystemNode(from.substring(0, from.length() - 1));
};
};
private static final Function<String, String>
TO_SHORT_PATH = new Function<String, String>() {
public String apply(String from) {
int idx = from.lastIndexOf('/');
if (idx < 0) {
return from;
}
return from.substring(idx + 1);
};
};
private String path;
private List<FileSystemNode> directories;
private List<String> files;
private String shortPath;
public FileSystemNode(String path) {
this.path = path;
int idx = path.lastIndexOf('/');
if (idx != -1) {
shortPath = path.substring(idx + 1);
} else {
shortPath = path;
}
}
public synchronized List<FileSystemNode> getDirectories() {
if (directories == null) {
directories = Lists.newArrayList();
Iterables.addAll(directories, transform(filter(
getResourcePaths(), containsPattern("/$")), FACTORY));
}
return directories;
}
public synchronized List<String> getFiles() {
if (files == null) {
files = new ArrayList<String>();
Iterables.addAll(files, transform(filter(
getResourcePaths(), not(containsPattern("/$"))), TO_SHORT_PATH));
}
return files;
}
private Iterable<String> getResourcePaths() {
FacesContext facesContext = FacesContext.getCurrentInstance();
ExternalContext externalContext = facesContext.getExternalContext();
Set<String> resourcePaths = externalContext.getResourcePaths(this.path);
if (resourcePaths == null) {
resourcePaths = Collections.emptySet();
}
return resourcePaths;
}
public String getShortPath() {
return shortPath;
}
}
उपरोक्त उदाहरण ब्राउज़र में निम्न आउटपुट का उत्पादन करेगा।