X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=server%2Fplugins%2Forg.argeo.jcr.ui.explorer%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fjcr%2Fui%2Fexplorer%2Futils%2FJcrUiUtils.java;h=e8c0cb7a29871794f0f0c07e4ba6236fd44fabb4;hb=0450e423bd759c9e27b43044670e659271392d71;hp=756748bb4b4042a03ccc42770b7615812d60cb47;hpb=1d5afdce3e91054f07ddd3c98309c363b4cf1d46;p=lgpl%2Fargeo-commons.git diff --git a/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/utils/JcrUiUtils.java b/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/utils/JcrUiUtils.java index 756748bb4..e8c0cb7a2 100644 --- a/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/utils/JcrUiUtils.java +++ b/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/utils/JcrUiUtils.java @@ -20,30 +20,45 @@ import javax.jcr.RepositoryException; import org.argeo.ArgeoException; import org.argeo.eclipse.ui.TreeParent; +import org.argeo.jcr.ui.explorer.model.RepositoriesNode; +import org.argeo.jcr.ui.explorer.model.RepositoryNode; import org.argeo.jcr.ui.explorer.model.SingleJcrNode; import org.argeo.jcr.ui.explorer.model.WorkspaceNode; -/** Centralizes some useful methods to build Uis with JCR */ +/** Centralizes some useful methods to build UIs with JCR */ public class JcrUiUtils { - /** Insure that the UI componant is not stale, refresh if needed */ + /** Insure that the UI component is not stale, refresh if needed */ public static void forceRefreshIfNeeded(TreeParent element) { - Node curNode; + Node curNode = null; - if (element instanceof SingleJcrNode) - curNode = ((SingleJcrNode) element).getNode(); - else if (element instanceof WorkspaceNode) - curNode = ((WorkspaceNode) element).getRootNode(); - else - return; - // TODO implement specific methods for other cases + boolean doRefresh = false; try { - // we mainly rely on nb of children - if (element.getChildren().length == curNode.getNodes().getSize()) - return; - else { - // get rid of children of UI object + if (element instanceof SingleJcrNode) { + curNode = ((SingleJcrNode) element).getNode(); + } else if (element instanceof WorkspaceNode) { + curNode = ((WorkspaceNode) element).getRootNode(); + } + + if (curNode != null + && element.getChildren().length != curNode.getNodes() + .getSize()) + doRefresh = true; + else if (element instanceof RepositoryNode) { + RepositoryNode rn = (RepositoryNode) element; + if (rn.isConnected()) { + String[] wkpNames = rn.getAccessibleWorkspaceNames(); + if (element.getChildren().length != wkpNames.length) + doRefresh = true; + } + } else if (element instanceof RepositoriesNode) { + RepositoriesNode rn = (RepositoriesNode) element; + if (element.getChildren().length != rn.getRepositoryRegister() + .getRepositories().size()) + doRefresh = true; + } + if (doRefresh) { element.clearChildren(); element.getChildren(); }