initial quantum version
[phpeclipse.git] / archive / net.sourceforge.phpeclipse.quantum.sql / src / com / quantum / view / bookmark / RenameAction.java
diff --git a/archive/net.sourceforge.phpeclipse.quantum.sql/src/com/quantum/view/bookmark/RenameAction.java b/archive/net.sourceforge.phpeclipse.quantum.sql/src/com/quantum/view/bookmark/RenameAction.java
new file mode 100644 (file)
index 0000000..175c68a
--- /dev/null
@@ -0,0 +1,52 @@
+package com.quantum.view.bookmark;
+
+import com.quantum.Messages;
+import com.quantum.model.Bookmark;
+
+import org.eclipse.jface.dialogs.InputDialog;
+import org.eclipse.jface.viewers.IStructuredSelection;
+import org.eclipse.ui.IViewPart;
+import org.eclipse.ui.actions.SelectionListenerAction;
+
+/**
+ * @author BC
+ */
+public class RenameAction extends SelectionListenerAction {
+
+    private IViewPart viewPart;
+
+    /**
+     * @param text
+     */
+    protected RenameAction(IViewPart viewPart) {
+        super(Messages.getString(RenameAction.class.getName() + ".text"));
+        this.viewPart = viewPart;
+    }
+    
+    
+
+    /**
+     * @see org.eclipse.ui.actions.SelectionListenerAction#updateSelection(org.eclipse.jface.viewers.IStructuredSelection)
+     */
+    protected boolean updateSelection(IStructuredSelection selection) {
+        boolean enabled = super.updateSelection(selection);
+        return enabled & selection.size() == 1 & 
+            selection.getFirstElement() instanceof BookmarkNode;
+    }
+    
+    private Bookmark getBookmark() {
+        return ((BookmarkNode) getSelectedNonResources().get(0)).getBookmark();
+    }
+
+    /**
+     * @see org.eclipse.jface.action.IAction#run()
+     */
+    public void run() {
+        InputDialog dialog = new InputDialog(this.viewPart.getSite().getShell(), "Select a new name",
+            "Name: ", getBookmark().getName(), null);
+        int result = dialog.open();
+        if (result == InputDialog.OK) {
+            getBookmark().setName(dialog.getValue());
+        }
+    }
+}