X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.app.ui%2Fsrc%2Forg%2Fargeo%2Fapp%2Fui%2Flibrary%2FJcrContentEntryArea.java;fp=org.argeo.app.ui%2Fsrc%2Forg%2Fargeo%2Fapp%2Fui%2Flibrary%2FJcrContentEntryArea.java;h=0000000000000000000000000000000000000000;hb=d917d2b10162a29cddaf8c81c362efa37abcaab9;hp=d86eef283b72aa8d139d396fe19a43f1466a9d6a;hpb=f1b87af2e0de38f1f49ab8fe68f9988018914811;p=gpl%2Fargeo-suite.git diff --git a/org.argeo.app.ui/src/org/argeo/app/ui/library/JcrContentEntryArea.java b/org.argeo.app.ui/src/org/argeo/app/ui/library/JcrContentEntryArea.java deleted file mode 100644 index d86eef2..0000000 --- a/org.argeo.app.ui/src/org/argeo/app/ui/library/JcrContentEntryArea.java +++ /dev/null @@ -1,178 +0,0 @@ -package org.argeo.app.ui.library; - -import java.util.SortedMap; -import java.util.TreeMap; - -import javax.jcr.Node; -import javax.jcr.NodeIterator; -import javax.jcr.RepositoryException; -import javax.jcr.Session; -import javax.jcr.nodetype.NodeType; -import javax.jcr.query.Query; - -import org.argeo.api.acr.Content; -import org.argeo.api.cms.CmsConstants; -import org.argeo.app.api.EntityType; -import org.argeo.app.ui.SuiteEvent; -import org.argeo.app.ui.SuiteIcon; -import org.argeo.app.ui.widgets.TreeOrSearchArea; -import org.argeo.cms.jcr.acr.JcrContentProvider; -import org.argeo.cms.swt.CmsSwtTheme; -import org.argeo.cms.swt.CmsSwtUtils; -import org.argeo.cms.ui.CmsUiProvider; -import org.argeo.jcr.Jcr; -import org.argeo.jcr.JcrException; -import org.eclipse.jface.viewers.ColumnLabelProvider; -import org.eclipse.jface.viewers.DoubleClickEvent; -import org.eclipse.jface.viewers.IDoubleClickListener; -import org.eclipse.jface.viewers.ISelectionChangedListener; -import org.eclipse.jface.viewers.ITreeContentProvider; -import org.eclipse.jface.viewers.SelectionChangedEvent; -import org.eclipse.jface.viewers.TreeViewerColumn; -import org.eclipse.jface.viewers.Viewer; -import org.eclipse.swt.SWT; -import org.eclipse.swt.graphics.Image; -import org.eclipse.swt.layout.GridLayout; -import org.eclipse.swt.widgets.Composite; -import org.eclipse.swt.widgets.Control; - -public class JcrContentEntryArea implements CmsUiProvider { - private JcrContentProvider jcrContentProvider; - - @Override - public Control createUiPart(Composite parent, Content context) { - CmsSwtTheme theme = CmsSwtUtils.getCmsTheme(parent); - - parent.setLayout(new GridLayout()); - Ui ui = new Ui(parent, SWT.NONE); - ui.setLayoutData(CmsSwtUtils.fillAll()); - - TreeViewerColumn nameCol = new TreeViewerColumn(ui.getTreeViewer(), SWT.NONE); - nameCol.getColumn().setWidth(400); - nameCol.setLabelProvider(new ColumnLabelProvider() { - - @Override - public String getText(Object element) { - Node node = (Node) element; - return Jcr.getTitle(node); - } - - @Override - public Image getImage(Object element) { - Node node = (Node) element; - Image icon; - if (Jcr.isNodeType(node, NodeType.NT_FOLDER)) { - icon = theme.getSmallIcon(SuiteIcon.folder); - } else if (Jcr.isNodeType(node, NodeType.NT_FILE)) { - // TODO check recognized document types - icon = theme.getSmallIcon(SuiteIcon.document); - } else if (Jcr.isNodeType(node, EntityType.document.get())) { - icon = theme.getSmallIcon(SuiteIcon.document); - } else { - if (!isLeaf(node)) - icon = theme.getSmallIcon(SuiteIcon.folder); - else - icon = null; - } - return icon; - } - - }); - - ui.getTreeViewer().addDoubleClickListener(new IDoubleClickListener() { - - @Override - public void doubleClick(DoubleClickEvent event) { - Node user = (Node) ui.getTreeViewer().getStructuredSelection().getFirstElement(); - if (user != null) { - CmsSwtUtils.getCmsView(parent).sendEvent(SuiteEvent.openNewPart.topic(), - SuiteEvent.eventProperties(user)); - } - - } - }); - ui.getTreeViewer().addSelectionChangedListener(new ISelectionChangedListener() { - public void selectionChanged(SelectionChangedEvent event) { - Node user = (Node) ui.getTreeViewer().getStructuredSelection().getFirstElement(); - if (user != null) { - CmsSwtUtils.getCmsView(parent).sendEvent(SuiteEvent.refreshPart.topic(), - SuiteEvent.eventProperties(user)); - } - } - }); - - ui.getTreeViewer().setContentProvider(new SpacesContentProvider()); - Session session = jcrContentProvider.getJcrSession(context, CmsConstants.SYS_WORKSPACE); - ui.getTreeViewer().setInput(session); - return ui; - } - - protected boolean isLeaf(Node node) { - return Jcr.isNodeType(node, EntityType.entity.get()) || Jcr.isNodeType(node, EntityType.document.get()) - || Jcr.isNodeType(node, NodeType.NT_FILE); - } - - public void setJcrContentProvider(JcrContentProvider jcrContentProvider) { - this.jcrContentProvider = jcrContentProvider; - } - - class Ui extends TreeOrSearchArea { - - public Ui(Composite parent, int style) { - super(parent, style); - } - - } - - class SpacesContentProvider implements ITreeContentProvider { - - @Override - public Object[] getElements(Object inputElement) { - Session session = (Session) inputElement; - try { - Query query = session.getWorkspace().getQueryManager() - .createQuery("SELECT * FROM [" + EntityType.space.get() + "]", Query.JCR_SQL2); - NodeIterator spacesIt = query.execute().getNodes(); - SortedMap map = new TreeMap<>(); - while (spacesIt.hasNext()) { - Node space = spacesIt.nextNode(); - String path = space.getPath(); - map.put(path, space); - } - return map.values().toArray(); - } catch (RepositoryException e) { - throw new JcrException(e); - } - } - - @Override - public Object[] getChildren(Object parentElement) { - Node parent = (Node) parentElement; - if (isLeaf(parent)) - return null; - return Jcr.getNodes(parent).toArray(); - } - - @Override - public Object getParent(Object element) { - Node node = (Node) element; - return Jcr.getParent(node); - } - - @Override - public boolean hasChildren(Object element) { - Node node = (Node) element; - return !isLeaf(node); - } - - @Override - public void dispose() { - } - - @Override - public void inputChanged(Viewer viewer, Object oldInput, Object newInput) { - } - - } - -}