- split off "Preparation/Preservation section" from dna sample general
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / ui / section / occurrence / dna / DnaSampleGeneralDetailElement.java
index 2cbf45f6bee259a6eac4a1096ad76c94a78d630d..677252846b6e1e3e3518b51c84fb08dd6d532364 100644 (file)
@@ -9,20 +9,12 @@
 */
 package eu.etaxonomy.taxeditor.ui.section.occurrence.dna;
 
-import eu.etaxonomy.cdm.model.agent.AgentBase;
-import eu.etaxonomy.cdm.model.agent.Institution;
-import eu.etaxonomy.cdm.model.common.DefinedTerm;
-import eu.etaxonomy.cdm.model.common.TermType;
-import eu.etaxonomy.cdm.model.common.TimePeriod;
 import eu.etaxonomy.cdm.model.molecular.DnaSample;
-import eu.etaxonomy.cdm.model.occurrence.PreservationMethod;
-import eu.etaxonomy.taxeditor.ui.combo.TermComboElement;
+import eu.etaxonomy.cdm.model.occurrence.Collection;
 import eu.etaxonomy.taxeditor.ui.element.CdmFormFactory;
 import eu.etaxonomy.taxeditor.ui.element.CheckboxElement;
 import eu.etaxonomy.taxeditor.ui.element.ICdmFormElement;
-import eu.etaxonomy.taxeditor.ui.element.NumberWithLabelElement;
 import eu.etaxonomy.taxeditor.ui.element.TextWithLabelElement;
-import eu.etaxonomy.taxeditor.ui.element.TimePeriodElement;
 import eu.etaxonomy.taxeditor.ui.section.AbstractCdmDetailElement;
 import eu.etaxonomy.taxeditor.ui.selection.EntitySelectionElement;
 
@@ -33,100 +25,37 @@ import eu.etaxonomy.taxeditor.ui.selection.EntitySelectionElement;
  */
 public class DnaSampleGeneralDetailElement extends AbstractCdmDetailElement<DnaSample> {
 
-    private EntitySelectionElement<Institution> selectionInstitution;
-    private EntitySelectionElement<AgentBase> selectionStaff;
-    private TimePeriodElement datePreparationDate;
-    private NumberWithLabelElement numberPreservationTemperature;
-    private TermComboElement<DefinedTerm> comboMaterialOrMethods;
+
+    private EntitySelectionElement<Collection> selection_collection;
     private TextWithLabelElement textBarcode;
     private CheckboxElement checkIsPublish;
 
-    /**
-     * @param formFactory
-     * @param formElement
-     */
     public DnaSampleGeneralDetailElement(CdmFormFactory formFactory, ICdmFormElement formElement) {
         super(formFactory, formElement);
     }
 
-    /*
-     * (non-Javadoc)
-     *
-     * @see
-     * eu.etaxonomy.taxeditor.section.AbstractCdmDetailElement#createControls
-     * (eu.etaxonomy.taxeditor.forms.ICdmFormElement, java.lang.Object, int)
-     */
     @Override
     protected void createControls(ICdmFormElement formElement, DnaSample entity, int style) {
-        Institution institution = null;
-        AgentBase<?> staff = null;
-        TimePeriod preparationDate = null;
-        if(entity.getDerivedFrom()!=null){
-            institution = entity.getDerivedFrom().getInstitution();
-            staff = entity.getDerivedFrom().getActor();
-            preparationDate = entity.getDerivedFrom().getTimeperiod();
-        }
-
-        Double temperature = null;
-        DefinedTerm definedMaterialOrMethod = null;
-        if(entity.getPreservation()!=null){
-            temperature = entity.getPreservation().getTemperature();
-            definedMaterialOrMethod = entity.getPreservation().getDefinedMaterialOrMethod();
-        }
-        selectionInstitution = formFactory.createSelectionElement(Institution.class, getConversationHolder(), formElement, "Institution", institution, EntitySelectionElement.ALL, style);
-        selectionStaff = formFactory.createSelectionElement(AgentBase.class, getConversationHolder(), formElement, "Staff", staff, EntitySelectionElement.ALL, style);
-        datePreparationDate = formFactory.createTimePeriodElement(formElement, "Preparation date", preparationDate, style);
-        numberPreservationTemperature = formFactory.createNumberTextWithLabelElement(formElement, "Preservation Temp. [C°]", temperature, style);
-        comboMaterialOrMethods = formFactory.createDefinedTermComboElement(TermType.MaterialOrMethod, formElement, "Materials & Methods", definedMaterialOrMethod, style);
+        selection_collection = formFactory
+                .createSelectionElement(Collection.class,
+                        getConversationHolder(), formElement, "Collection",
+                        entity.getCollection(),
+                        EntitySelectionElement.ALL, style);
         textBarcode = formFactory.createTextWithLabelElement(formElement, "Barcode", entity.getBarcode(), style);
         checkIsPublish = formFactory.createCheckbox(formElement, "Publish", entity.isPublish(), style);
 
     }
 
-    /*
-     * (non-Javadoc)
-     *
-     * @see
-     * eu.etaxonomy.taxeditor.section.AbstractCdmDetailElement#handleEvent(java
-     * .lang.Object)
-     */
     @Override
     public void handleEvent(Object eventSource) {
-        if(eventSource==datePreparationDate){
-            if(getEntity().getDerivedFrom()!=null){
-                getEntity().getDerivedFrom().setTimeperiod(datePreparationDate.getTimePeriod());
-            }
-        }
-        else if(eventSource==selectionInstitution){
-            if(getEntity().getDerivedFrom()!=null){
-                getEntity().getDerivedFrom().setInstitution(selectionInstitution.getSelection());
-            }
-        }
-        else if(eventSource==selectionStaff){
-            if(getEntity().getDerivedFrom()!=null){
-                getEntity().getDerivedFrom().setActor(selectionStaff.getSelection());
-            }
-        }
-        else if(eventSource==numberPreservationTemperature){
-            addPreservationMethod().setTemperature(numberPreservationTemperature.getDouble());
-        }
-        else if(eventSource==comboMaterialOrMethods){
-            addPreservationMethod().setDefinedMaterialOrMethod(comboMaterialOrMethods.getSelection());
-        }
-        else if(eventSource==textBarcode){
+        if(eventSource==textBarcode){
             getEntity().setBarcode(textBarcode.getText());
         }
         else if(eventSource==checkIsPublish){
             getEntity().setPublish(checkIsPublish.getSelection());
+        } else if (eventSource == selection_collection) {
+            getEntity().setCollection(selection_collection.getSelection());
         }
     }
 
-    private PreservationMethod addPreservationMethod(){
-        PreservationMethod preservationMethod = getEntity().getPreservation();
-        if(preservationMethod==null){
-            preservationMethod = PreservationMethod.NewInstance();
-            getEntity().setPreservation(preservationMethod);
-        }
-        return preservationMethod;
-    }
 }