merge-update from trunk
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / view / AbstractCdmEditorViewPart.java
index afa592fa171aa06f0426f840532ede686655fd36..67a0bae278427199ca11a16728dd6b9f0a7db64d 100644 (file)
 /**
- * 
+ *
  */
 package eu.etaxonomy.taxeditor.view;
 
+import org.eclipse.jface.viewers.ISelection;
 import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Display;
 import org.eclipse.ui.IEditorPart;
+import org.eclipse.ui.IWorkbenchPart;
 
+import eu.etaxonomy.taxeditor.editor.ISecuredEditor;
+import eu.etaxonomy.taxeditor.model.AbstractUtility;
 import eu.etaxonomy.taxeditor.model.IDirtyMarkableSelectionProvider;
-import eu.etaxonomy.taxeditor.store.StoreUtil;
 
 /**
  * <p>
  * Abstract AbstractCdmEditorViewPart class.
  * </p>
- * 
+ *
  * @author n.hoffmann
  * @created Sep 21, 2010
  * @version 1.0
  */
 public abstract class AbstractCdmEditorViewPart extends AbstractCdmViewPart {
 
-       /*
-        * (non-Javadoc)
-        * 
-        * @see
-        * eu.etaxonomy.taxeditor.model.AbstractCdmViewPart#createPartControl(org
-        * .eclipse.swt.widgets.Composite)
-        */
-       /** {@inheritDoc} */
-       @Override
-       public void createPartControl(Composite parent) {
-
-               super.createPartControl(parent);
-
-       }
-
-       /**
-        * <p>
-        * getEditor
-        * </p>
-        * 
-        * @return the currently active editor
-        */
-       public IEditorPart getEditor() {
-               return StoreUtil.getActiveEditor();
-       }
-
-       /** {@inheritDoc} */
-       @Override
-       public void changed(Object object) {
-               if (part instanceof AbstractCdmViewPart) {
-                       ((AbstractCdmViewPart) part).changed(object);
-               } else {
-                       IEditorPart editor = getEditor();
-                       if (editor != null
-                                       && editor instanceof IDirtyMarkableSelectionProvider) {
-
-                               ((IDirtyMarkableSelectionProvider) editor).changed(object);
-
-                       }
-               }
-       }
+    private DelaySelection delaySelection = null;
+    /**
+     * This is the monitor for the DelaySelection runnable.
+     * If it is <code>true</code> then it is currently delaying a selection.
+     */
+    private boolean isInDelay = false;
+
+
+    /**
+     * This class invokes internal_selectionChanged() in a separate thread.
+     * This allows an asynchronous and/or delayed handling of selection changes
+     */
+    private class DelaySelection implements Runnable{
+        private IWorkbenchPart part;
+        private ISelection selection;
+
+        public DelaySelection(IWorkbenchPart part, ISelection selection) {
+            super();
+            this.part = part;
+            this.selection = selection;
+        }
+
+        /* (non-Javadoc)
+         * @see java.lang.Runnable#run()
+         */
+        @Override
+        public void run() {
+            internal_selectionChanged(part, selection);
+            isInDelay = false;
+        }
+
+        public synchronized void setSelection(ISelection selection) {
+            this.selection = selection;
+        }
+
+        public synchronized void setPart(IWorkbenchPart part) {
+            this.part = part;
+        }
+
+    }
+
+    /**
+     * Handle selection change events here and <b>not</b> in
+     * {@link AbstractCdmEditorViewPart#selectionChanged(IWorkbenchPart, ISelection)}
+     * if you want asynchronous selection handling.
+     * @param part The workbench part that has issued the selection change
+     * @param selection the new selection
+     */
+    protected abstract void internal_selectionChanged(IWorkbenchPart part, ISelection selection);
+
+    /** {@inheritDoc} */
+    @Override
+    public void selectionChanged(IWorkbenchPart part, ISelection selection) {
+        if(delaySelection==null){
+            delaySelection = new DelaySelection(part, selection);
+        }
+        delaySelection.setPart(part);
+        delaySelection.setSelection(selection);
+        if(!isInDelay){
+            isInDelay = true;
+            Display.getCurrent().asyncExec(delaySelection);
+        }
+    }
+
+    /*
+     * (non-Javadoc)
+     *
+     * @see
+     * eu.etaxonomy.taxeditor.model.AbstractCdmViewPart#createPartControl(org
+     * .eclipse.swt.widgets.Composite)
+     */
+    /** {@inheritDoc} */
+    @Override
+    public void createPartControl(Composite parent) {
+        super.createPartControl(parent);
+    }
+
+    /**
+     * <p>
+     * getEditor
+     * </p>
+     *
+     * @return the currently active editor
+     */
+    public IEditorPart getEditor() {
+        return AbstractUtility.getActiveEditor();
+    }
+
+    /** {@inheritDoc} */
+    @Override
+    public void setFocus() {
+        super.setFocus();
+
+        if(getEditor() != null && ISecuredEditor.class.isAssignableFrom(getEditor().getClass())){
+            boolean doEnable = ((ISecuredEditor)getEditor()).permissionsSatisfied();
+            setEnabled(doEnable);
+        }
+    }
+
+    /** {@inheritDoc} */
+    @Override
+    public void changed(Object object) {
+        if (part instanceof AbstractCdmViewPart) {
+            ((AbstractCdmViewPart) part).changed(object);
+        } else {
+            IEditorPart editor = getEditor();
+            if (editor != null && editor instanceof IDirtyMarkableSelectionProvider) {
+                ((IDirtyMarkableSelectionProvider) editor).changed(object);
+            }
+        }
+    }
 
 }