import javax.jcr.RepositoryException;
import javax.jcr.Session;
-import org.argeo.jcr.ArgeoNames;
import org.argeo.jcr.JcrUtils;
import org.argeo.slc.SlcException;
import org.argeo.slc.client.ui.dist.DistPlugin;
-import org.argeo.slc.client.ui.dist.views.DistributionsView;
-import org.argeo.slc.client.ui.dist.views.DistributionsView.DistributionViewSelectedElement;
+import org.argeo.slc.client.ui.dist.model.RepoElem;
import org.eclipse.core.commands.AbstractHandler;
import org.eclipse.core.commands.ExecutionEvent;
import org.eclipse.core.commands.ExecutionException;
import org.eclipse.jface.dialogs.Dialog;
import org.eclipse.jface.dialogs.IDialogConstants;
+import org.eclipse.jface.viewers.IStructuredSelection;
import org.eclipse.swt.SWT;
import org.eclipse.swt.graphics.Point;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.swt.widgets.Text;
-import org.eclipse.ui.IWorkbenchPart;
-import org.eclipse.ui.IWorkbenchWindow;
+import org.eclipse.ui.handlers.HandlerUtil;
/**
* Create a new empty workspace in the current repository.
public final static String DEFAULT_ICON_PATH = "icons/help.gif";
public Object execute(ExecutionEvent event) throws ExecutionException {
- IWorkbenchWindow iww = DistPlugin.getDefault().getWorkbench()
- .getActiveWorkbenchWindow();
- IWorkbenchPart view = iww.getActivePage().getActivePart();
- if (view instanceof DistributionsView) {
- DistributionViewSelectedElement dvse = ((DistributionsView) view)
- .getSelectedElement();
- if (dvse != null && (dvse.isRepository)) {
- InformationDialog inputDialog = new InformationDialog(
- iww.getShell());
- inputDialog.create();
- Session session = null;
- try {
- session = dvse.repository.login(dvse.credentials);
- inputDialog.loginTxt.setText(session.getUserID());
-
- inputDialog.nameTxt.setText(dvse.repoNode.getName());
- inputDialog.uriTxt.setText(JcrUtils.get(dvse.repoNode,
- ArgeoNames.ARGEO_URI));
- inputDialog.readOnlyBtn.setSelection(dvse.isReadOnly);
-
- } catch (RepositoryException e) {
- throw new SlcException("Unexpected error while "
- + "getting repository infos.", e);
- } finally {
- JcrUtils.logoutQuietly(session);
- }
- inputDialog.open();
+
+ IStructuredSelection iss = (IStructuredSelection) HandlerUtil
+ .getActiveSite(event).getSelectionProvider().getSelection();
+
+ if (iss.getFirstElement() instanceof RepoElem) {
+ RepoElem re = (RepoElem) iss.getFirstElement();
+ InformationDialog inputDialog = new InformationDialog(HandlerUtil
+ .getActiveSite(event).getShell());
+ inputDialog.create();
+ Session session = null;
+ try {
+ session = re.getRepository().login(re.getCredentials());
+ inputDialog.loginTxt.setText(session.getUserID());
+ inputDialog.nameTxt.setText(re.getLabel());
+ inputDialog.uriTxt.setText(re.getUri());
+ inputDialog.readOnlyBtn.setSelection(re.isReadOnly());
+ } catch (RepositoryException e) {
+ throw new SlcException("Unexpected error while "
+ + "getting repository infos.", e);
+ } finally {
+ JcrUtils.logoutQuietly(session);
}
+ inputDialog.open();
}
return null;
}
@Override
protected void createButtonsForButtonBar(Composite parent) {
// No Cancel button
- createButton(parent, IDialogConstants.OK_ID,
- IDialogConstants.OK_LABEL, true);
+ createButton(parent, IDialogConstants.OK_ID, "OK", true);
}
public InformationDialog(Shell parentShell) {