ref #7985: adapt Proceedings details view
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / ui / section / reference / ReferenceDetailElement.java
old mode 100755 (executable)
new mode 100644 (file)
index 259fbff..d5d5b66
@@ -16,30 +16,26 @@ import java.util.Arrays;
 import java.util.List;
 
 import org.eclipse.swt.SWT;
-import org.eclipse.swt.widgets.Display;
 import org.joda.time.DateTime;
 
-import eu.etaxonomy.cdm.common.CdmUtils;
 import eu.etaxonomy.cdm.model.agent.AgentBase;
 import eu.etaxonomy.cdm.model.agent.Institution;
 import eu.etaxonomy.cdm.model.agent.TeamOrPersonBase;
 import eu.etaxonomy.cdm.model.reference.Reference;
 import eu.etaxonomy.cdm.model.reference.ReferenceFactory;
 import eu.etaxonomy.cdm.model.reference.ReferenceType;
-import eu.etaxonomy.taxeditor.model.DateConverter;
-import eu.etaxonomy.taxeditor.store.CdmStore;
+import eu.etaxonomy.taxeditor.store.StoreUtil;
 import eu.etaxonomy.taxeditor.ui.combo.EnumComboElement;
 import eu.etaxonomy.taxeditor.ui.element.CdmFormFactory;
 import eu.etaxonomy.taxeditor.ui.element.CdmPropertyChangeEvent;
+import eu.etaxonomy.taxeditor.ui.element.DoiWithLabelElement;
 import eu.etaxonomy.taxeditor.ui.element.ICdmFormElement;
 import eu.etaxonomy.taxeditor.ui.element.IErrorIntolerableElement;
 import eu.etaxonomy.taxeditor.ui.element.IExceptionHandler;
-import eu.etaxonomy.taxeditor.ui.element.LabelElement;
-import eu.etaxonomy.taxeditor.ui.element.LayoutConstants;
 import eu.etaxonomy.taxeditor.ui.element.TextWithLabelElement;
-import eu.etaxonomy.taxeditor.ui.element.TimePeriodElement;
 import eu.etaxonomy.taxeditor.ui.element.ToggleableTextElement;
 import eu.etaxonomy.taxeditor.ui.element.UriWithLabelElement;
+import eu.etaxonomy.taxeditor.ui.element.VerbatimTimePeriodElement;
 import eu.etaxonomy.taxeditor.ui.mvc.element.DateElement;
 import eu.etaxonomy.taxeditor.ui.section.AbstractIdentifiableEntityDetailElement;
 import eu.etaxonomy.taxeditor.ui.selection.EntitySelectionElement;
@@ -51,7 +47,6 @@ import eu.etaxonomy.taxeditor.ui.selection.EntitySelectionElement;
  *
  * @author n.hoffmann
  * @created Mar 2, 2010
- * @version 1.0
  */
 public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElement<Reference>
                implements IErrorIntolerableElement, IExceptionHandler {
@@ -74,10 +69,11 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
        private TextWithLabelElement text_volume;
        private TextWithLabelElement text_abbrevTitle;
        private TextWithLabelElement text_title;
+       private DoiWithLabelElement text_doi;
        private UriWithLabelElement text_uri;
        private DateElement text_accessed;
        private EntitySelectionElement<AgentBase> selection_authorTeam;
-       private TimePeriodElement element_timePeriod;
+       private VerbatimTimePeriodElement element_timePeriod;
        private EntitySelectionElement<Reference> selection_inReference;
        private EntitySelectionElement<Institution> selection_institution;
        private EnumComboElement<ReferenceType> combo_referenceType;
@@ -105,30 +101,18 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                this.isWizard = isWizard;
        }
 
-       /*
-        * (non-Javadoc)
-        *
-        * @see
-        * eu.etaxonomy.taxeditor.forms.section.cdmdetail.AbstractCdmDetailComposite
-        * #createControl(org.eclipse.swt.widgets.Composite, int)
-        */
+
        /** {@inheritDoc} */
        @Override
        protected void createControls(ICdmFormElement formElement,
                        Reference entity, int style) {
-               ICdmFormElement o = this.getParentElement();
-               Class clazz=o.getClass();
-               if (isWizard){
-                   setWarnForReferencingObjects(formElement);
-               }
-
-
+               setWarnForReferencingObjects(formElement);
                toggleable_cache = formFactory.createToggleableTextField(formElement,
                                "Reference Cache", entity.getTitleCache(),
                                entity.isProtectedTitleCache(), style);
 
                toggleableAbbrevCache = formFactory.createToggleableTextField(formElement,
-                       "Abbrev. Cache", entity.getAbbrevTitleCache(),
+                       "Nomencl. Cache", entity.getAbbrevTitleCache(),
                        entity.isProtectedAbbrevTitleCache(), style);
 
                combo_referenceType = formFactory.createEnumComboElement(ReferenceType.class,
@@ -141,16 +125,18 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                                "Title", entity.getTitle(), style);
                // abbreviated title
                text_abbrevTitle = formFactory.createTextWithLabelElement(formElement,
-                       "Nomenclatural Title", entity.getAbbrevTitle(), style);
-
+                       "Nomencl. Title", entity.getAbbrevTitle(), style);
+               ReferenceType referenceType = entity.getType();
                // author team
-               selection_authorTeam = formFactory
-                               .createSelectionElement(AgentBase.class,
-                                               getConversationHolder(), formElement, "Author",
-                                               entity.getAuthorship(),
-                                               EntitySelectionElement.ALL, style);
+               if(referenceType != null && !referenceType.equals(ReferenceType.Journal) && !referenceType.equals(ReferenceType.PrintSeries) ) {
+            selection_authorTeam = formFactory
+                       .createSelectionElement(AgentBase.class,//getConversationHolder(),
+                               formElement, "Author",
+                                       entity.getAuthorship(),
+                                       EntitySelectionElement.ALL, style);
+        }
+
 
-               ReferenceType referenceType = entity.getType();
 
                if (referenceType != null) {
 
@@ -159,12 +145,16 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                        if (referenceType.equals(ReferenceType.Generic)) {
                                createGenericControls(this, entity, SWT.NULL);
                                createPublicationControls(this, referenceType, entity, SWT.NULL);
-                               
+
                        } else {
                                if (referenceType.isPrintedUnit()) {
                                        createPrintedUnitControls(this, referenceType, entity,
                                                        SWT.NULL);
                                }
+//                             if (referenceType.equals(ReferenceType.Proceedings)) {
+//                                 text_isbn = formFactory.createTextWithLabelElement(this, "ISBN",
+//                                 entity.getIsbn(), style);
+//                }
                                if (referenceType.isPublication()) {
                                        createPublicationControls(this, referenceType, entity,
                                                        SWT.NULL);
@@ -175,24 +165,31 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                                if (referenceType.isSection()) {
                                        createSectionControls(this, entity, SWT.NULL);
                                }
-                               
+
                        }
                }
 
                // date published
-               element_timePeriod = formFactory.createTimePeriodElement(formElement,
-                               "Date Published", entity.getDatePublished(), style);
+               if(referenceType != null && !referenceType.equals(ReferenceType.Journal) && !referenceType.equals(ReferenceType.PrintSeries)){
+                   element_timePeriod = formFactory.createVerbatimTimePeriodElement(formElement,
+                           "Date Published", entity.getDatePublished(), style);
+               }
 
+
+               if(referenceType != null && (!referenceType.equals(ReferenceType.Journal) && !referenceType.equals(ReferenceType.PrintSeries) && !referenceType.equals(ReferenceType.PersonalCommunication))) {
+            text_doi = formFactory.createDoiWithLabelElement(formElement, "DOI", entity.getDoi(), style);
+        }
                createUriAndAbstract(this, entity, SWT.NULL);
+
                handleToggleableAbbrevTitleField();
                handleToggleableCacheField();
        }
 
        private void createWebPageControls(ReferenceDetailElement referenceDetailElement, Reference reference, int style) {
                DateTime accessed = reference.getAccessed();
-               
+
                 text_accessed = formFactory.createDateElement(referenceDetailElement, "Accessed", accessed, style, false);
-               
+
        }
 
        /*
@@ -242,7 +239,7 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                        label = "Book";
                        break;
                case InProceedings:
-                       label = "Print Series";
+                       label = "Proceedings";
                        break;
                case Article:
                        label = "Journal";
@@ -255,8 +252,8 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
 
                if (createInReferenceWidget) {
                        selection_inReference = formFactory
-                                       .createSelectionElement(Reference.class,
-                                                       getConversationHolder(), element, label,
+                                       .createSelectionElement(Reference.class,//getConversationHolder(),
+                                               element, label,
                                                        reference.getInReference(),
                                                        EntitySelectionElement.ALL, style);
                }
@@ -288,8 +285,8 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                // pages
                text_pages = formFactory.createTextWithLabelElement(element, "Pages",
                                reference.getPages(), style);
-               
-               
+
+
        }
 
        /**
@@ -320,8 +317,8 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                if (referenceType.equals(ReferenceType.Report)) {
                        // institution
                        selection_institution = formFactory
-                                       .createSelectionElement(Institution.class,
-                                                       getConversationHolder(), element, "Institution",
+                                       .createSelectionElement(Institution.class,//getConversationHolder(),
+                                               element, "Institution",
                                                        reference.getInstitution(),
                                                        EntitySelectionElement.ALL, style);
                }
@@ -329,8 +326,8 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                if (referenceType.equals(ReferenceType.Thesis)) {
                        // school
                        selection_institution = formFactory
-                                       .createSelectionElement(Institution.class,
-                                                       getConversationHolder(), element, "School",
+                                       .createSelectionElement(Institution.class,//getConversationHolder(),
+                                               element, "School",
                                                        reference.getSchool(),
                                                        EntitySelectionElement.ALL, style);
                }
@@ -384,8 +381,8 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                        ReferenceType referenceType, Reference reference, int style) {
                // in series
                selection_inSeries = formFactory
-                               .createSelectionElement(Reference.class,
-                                               getConversationHolder(), element, "In Series",
+                               .createSelectionElement(Reference.class,//getConversationHolder(),
+                                       element, "In Series",
                                                (Reference) reference.getInSeries(),
                                                EntitySelectionElement.ALL, style);
 
@@ -402,10 +399,10 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                        text_edition = formFactory.createTextWithLabelElement(element,
                                        "Edition", reference.getEdition(), style);
 
-                       // isbn
-                       text_isbn = formFactory.createTextWithLabelElement(element, "ISBN",
-                                       reference.getIsbn(), style);
                }
+               // isbn
+        text_isbn = formFactory.createTextWithLabelElement(element, "ISBN",
+                reference.getIsbn(), style);
        }
 
        private void createUriAndAbstract(ICdmFormElement element,
@@ -428,6 +425,8 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                if (eventSource == combo_referenceType) {
                        getEntity().setType(combo_referenceType.getSelection());
                        updateContent();
+               //this is needed for the "new" wizards in order to redraw correctly
+                       StoreUtil.reflowParentScrolledForm(getLayoutComposite(), true);
                } else if (eventSource == element_timePeriod) {
                        getEntity().setDatePublished(element_timePeriod.getTimePeriod());
                        clearException();
@@ -435,7 +434,7 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                // selections
                else if (eventSource == selection_authorTeam) {
                        getEntity().setAuthorship(
-                                       (TeamOrPersonBase) selection_authorTeam.getSelection());
+                                       (TeamOrPersonBase) selection_authorTeam.getEntity());
                } else if (eventSource == selection_inReference) {
                        getEntity().setInReference(selection_inReference.getSelection());
                } else if (eventSource == selection_inSeries) {
@@ -484,9 +483,11 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                        getEntity().setUri(text_uri.parseText());
                } else if (eventSource == text_volume) {
                        getEntity().setVolume(text_volume.getText());
-               }else if (eventSource == text_accessed.getController()) {
-                       getEntity().setAccessed(text_accessed.getController().getDateTime());
-               }
+               }else if (eventSource == text_doi) {
+            getEntity().setDoi(text_doi.parseText());
+        }else if (eventSource == text_accessed.getController()) {
+            getEntity().setAccessed(text_accessed.getController().getDateTime());
+        }
 
                if (eventSource != text_title && eventSource != text_abbrevTitle) {
                    // set abbrev title cache to null to force new generation
@@ -495,6 +496,10 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
                    if(!getEntity().isProtectedAbbrevTitleCache()){
                        getEntity().setAbbrevTitleCache(null, getEntity().isProtectedAbbrevTitleCache());
                    }
+                   if(!getEntity().isProtectedTitleCache()){
+                getEntity().setTitleCache(null, getEntity().isProtectedTitleCache());
+            }
+
                        toggleable_cache.setText(getEntity().getTitleCache());
                        toggleableAbbrevCache.setText(getEntity().getAbbrevTitleCache());
                }
@@ -603,15 +608,16 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
        protected void setIrrelevantReferenceDetail(boolean abbrev){
 
                List<Object> except = new ArrayList();
+
            except.addAll( Arrays.asList(new Object[] { toggleable_cache, toggleableAbbrevCache, text_editor, text_isbn, text_issn, text_organisation, text_pages, text_placePublished, text_publisher, text_referenceAbstract,  text_uri, selection_institution}));
            boolean pushedState;
            if (abbrev){
              except.add(text_title);
-             pushedState = toggleableAbbrevCache.getState();
            } else{
-               except.add(text_abbrevTitle);
-               pushedState = toggleable_cache.getState();
+             except.add(text_abbrevTitle);
            }
+           pushedState = toggleableAbbrevCache.getState() || toggleable_cache.getState();
+
            switch( getEntity().getType()){
            case Journal:
                except.add(element_timePeriod);
@@ -623,10 +629,13 @@ public class ReferenceDetailElement extends AbstractIdentifiableEntityDetailElem
            default:
                break;
            }
+
            setIrrelevant(pushedState, except);
+           text_title.setIrrelevant(toggleable_cache.getState());
+           text_abbrevTitle.setIrrelevant(toggleableAbbrevCache.getState());
        }
 
-       
+
 
 
 }