1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.argeo.cms.ui.jcr;
17
18 import java.util.ArrayList;
19 import java.util.Arrays;
20 import java.util.Comparator;
21 import java.util.List;
22
23 import javax.jcr.Node;
24 import javax.jcr.RepositoryException;
25 import javax.jcr.RepositoryFactory;
26 import javax.jcr.Session;
27 import javax.jcr.nodetype.NodeType;
28
29 import org.argeo.api.NodeConstants;
30 import org.argeo.api.NodeUtils;
31 import org.argeo.api.security.Keyring;
32 import org.argeo.cms.ui.jcr.model.RepositoriesElem;
33 import org.argeo.cms.ui.jcr.model.SingleJcrNodeElem;
34 import org.argeo.eclipse.ui.TreeParent;
35 import org.eclipse.jface.viewers.ITreeContentProvider;
36 import org.eclipse.jface.viewers.Viewer;
37
38
39
40
41
42 public class NodeContentProvider implements ITreeContentProvider {
43 private static final long serialVersionUID = -4083809398848374403L;
44 final private RepositoryRegister repositoryRegister;
45 final private RepositoryFactory repositoryFactory;
46
47
48 final private Session userSession;
49 final private Keyring keyring;
50 private boolean sortChildren;
51
52
53 private SingleJcrNodeElem homeNode = null;
54 private RepositoriesElem repositoriesNode = null;
55
56
57 private TreeBrowserComparator itemComparator = new TreeBrowserComparator();
58
59 public NodeContentProvider(Session userSession, Keyring keyring,
60 RepositoryRegister repositoryRegister,
61 RepositoryFactory repositoryFactory, Boolean sortChildren) {
62 this.userSession = userSession;
63 this.keyring = keyring;
64 this.repositoryRegister = repositoryRegister;
65 this.repositoryFactory = repositoryFactory;
66 this.sortChildren = sortChildren;
67 }
68
69 public void inputChanged(Viewer viewer, Object oldInput, Object newInput) {
70 if (newInput == null)
71 return;
72
73 if (userSession != null) {
74 Node userHome = NodeUtils.getUserHome(userSession);
75 if (userHome != null) {
76
77 if (homeNode != null)
78 homeNode.dispose();
79 homeNode = new SingleJcrNodeElem(null, userHome,
80 userSession.getUserID(), NodeConstants.EGO_REPOSITORY);
81 }
82 }
83 if (repositoryRegister != null) {
84 if (repositoriesNode != null)
85 repositoriesNode.dispose();
86 repositoriesNode = new RepositoriesElem("Repositories",
87 repositoryRegister, repositoryFactory, null, userSession,
88 keyring);
89 }
90 }
91
92
93
94
95
96 public Object[] getElements(Object inputElement) {
97 List<Object> objs = new ArrayList<Object>();
98 if (homeNode != null)
99 objs.add(homeNode);
100 if (repositoriesNode != null)
101 objs.add(repositoriesNode);
102 return objs.toArray();
103 }
104
105 public Object[] getChildren(Object parentElement) {
106 if (parentElement instanceof TreeParent) {
107 if (sortChildren) {
108 Object[] tmpArr = ((TreeParent) parentElement).getChildren();
109 if (tmpArr == null)
110 return new Object[0];
111 TreeParent[] arr = new TreeParent[tmpArr.length];
112 for (int i = 0; i < tmpArr.length; i++)
113 arr[i] = (TreeParent) tmpArr[i];
114 Arrays.sort(arr, itemComparator);
115 return arr;
116 } else
117 return ((TreeParent) parentElement).getChildren();
118 } else
119 return new Object[0];
120 }
121
122
123
124
125
126
127 public void setSortChildren(boolean sortChildren) {
128 this.sortChildren = sortChildren;
129 }
130
131 public Object getParent(Object element) {
132 if (element instanceof TreeParent) {
133 return ((TreeParent) element).getParent();
134 } else
135 return null;
136 }
137
138 public boolean hasChildren(Object element) {
139 if (element instanceof RepositoriesElem) {
140 RepositoryRegister rr = ((RepositoriesElem) element)
141 .getRepositoryRegister();
142 return rr.getRepositories().size() > 0;
143 } else if (element instanceof TreeParent) {
144 TreeParent tp = (TreeParent) element;
145 return tp.hasChildren();
146 }
147 return false;
148 }
149
150 public void dispose() {
151 if (homeNode != null)
152 homeNode.dispose();
153 if (repositoriesNode != null) {
154
155
156 repositoriesNode.dispose();
157 }
158 }
159
160
161
162
163
164 private class TreeBrowserComparator implements Comparator<TreeParent> {
165
166 public int category(TreeParent element) {
167 if (element instanceof SingleJcrNodeElem) {
168 Node node = ((SingleJcrNodeElem) element).getNode();
169 try {
170 if (node.isNodeType(NodeType.NT_FOLDER))
171 return 5;
172 } catch (RepositoryException e) {
173
174 e.printStackTrace();
175 }
176 }
177 return 10;
178 }
179
180 public int compare(TreeParent o1, TreeParent o2) {
181 int cat1 = category(o1);
182 int cat2 = category(o2);
183
184 if (cat1 != cat2) {
185 return cat1 - cat2;
186 }
187 return o1.getName().compareTo(o2.getName());
188 }
189 }
190 }