merge-update from trunk
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / ui / section / AbstractIdentifiableEntityDetailElement.java
index 0ef043a6b3b43e4e1001d03fa3713069c4feda74..2541c85bd437284f6360dc746fc2f784b4e75b1e 100644 (file)
@@ -4,10 +4,14 @@
 package eu.etaxonomy.taxeditor.ui.section;
 
 import java.util.Arrays;
+import java.util.EnumSet;
 
+import eu.etaxonomy.cdm.model.common.CdmBase;
 import eu.etaxonomy.cdm.model.common.IIdentifiableEntity;
-import eu.etaxonomy.taxeditor.ui.campanula.compatibility.ICdmFormElement;
+import eu.etaxonomy.cdm.persistence.hibernate.permission.CRUD;
+import eu.etaxonomy.taxeditor.store.CdmStore;
 import eu.etaxonomy.taxeditor.ui.element.CdmFormFactory;
+import eu.etaxonomy.taxeditor.ui.element.ICdmFormElement;
 import eu.etaxonomy.taxeditor.ui.element.ToggleableTextElement;
 
 /**
@@ -17,10 +21,16 @@ import eu.etaxonomy.taxeditor.ui.element.ToggleableTextElement;
 public abstract class AbstractIdentifiableEntityDetailElement<T extends IIdentifiableEntity> extends
         AbstractCdmDetailElement<T> {
 
+    /**
+     *
+     */
+    private static final EnumSet<CRUD> UPDATE = EnumSet.of(CRUD.UPDATE);
     protected ToggleableTextElement toggleable_cache;
 
     public AbstractIdentifiableEntityDetailElement(CdmFormFactory formFactory, ICdmFormElement formElement) {
         super(formFactory, formElement);
+        updateToggleableCacheState();
+
     }
 
     public void updateToggleableCacheField() {
@@ -36,4 +46,19 @@ public abstract class AbstractIdentifiableEntityDetailElement<T extends IIdentif
         setIrrelevant(pushedState, Arrays.asList(new Object[] { toggleable_cache }));
         updateToggleableCacheField();
     }
+
+
+    @Override
+    protected void updateControlStates(){
+        super.updateControlStates();
+        updateToggleableCacheState();
+    }
+
+
+    private void updateToggleableCacheState() {
+        if(toggleable_cache != null){
+            toggleable_cache.setEnabled(getEntity() != null && CdmStore.currentAuthentiationHasPermission((CdmBase) getEntity(), UPDATE));
+        }
+    }
+
 }