ref #8648: default handling in name details preference - continue
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / databaseAdmin / preferencePage / GeneralAdminPreferencePage.java
index 5b9f358fcfc463eb507cc080a18b0510bbc5f94a..54235a6518c2885b728e285aff17ac3284afab49 100755 (executable)
@@ -8,23 +8,14 @@
 */
 package eu.etaxonomy.taxeditor.databaseAdmin.preferencePage;
 
-import org.eclipse.swt.SWT;
-import org.eclipse.swt.events.SelectionAdapter;
-import org.eclipse.swt.events.SelectionEvent;
-import org.eclipse.swt.layout.GridLayout;
-import org.eclipse.swt.widgets.Button;
-import org.eclipse.swt.widgets.Composite;
-import org.eclipse.swt.widgets.Control;
-
 import eu.etaxonomy.cdm.api.application.ICdmRepository;
 import eu.etaxonomy.cdm.api.service.IPreferenceService;
 import eu.etaxonomy.cdm.model.metadata.CdmPreference;
 import eu.etaxonomy.cdm.model.metadata.CdmPreference.PrefKey;
 import eu.etaxonomy.cdm.model.metadata.PreferencePredicate;
 import eu.etaxonomy.cdm.model.metadata.PreferenceSubject;
-import eu.etaxonomy.taxeditor.l10n.Messages;
+import eu.etaxonomy.taxeditor.preference.GeneralPreferencePage;
 import eu.etaxonomy.taxeditor.preference.PreferencesUtil;
-import eu.etaxonomy.taxeditor.preference.menu.CdmPreferencePage;
 import eu.etaxonomy.taxeditor.store.CdmStore;
 
 /**
@@ -32,109 +23,112 @@ import eu.etaxonomy.taxeditor.store.CdmStore;
  * @since 29.05.2018
  *
  */
-public class GeneralAdminPreferencePage extends CdmPreferencePage implements IE4AdminPreferencePage {
-
+public class GeneralAdminPreferencePage extends GeneralPreferencePage implements IE4AdminPreferencePage {
 
-    boolean isShowIOMenu = true;
-    boolean isShowMediaView = true;
-    boolean isShowCheckListPerspective = false;
+    ICdmRepository controller = null;
+    CdmPreference isShowSpecimenPref = null;
     /**
      * {@inheritDoc}
      */
-    @Override
-    protected Control createContents(Composite parent) {
-        final Composite composite = new Composite(parent, SWT.NULL);
-
-        GridLayout gridLayout = new GridLayout();
-        composite.setLayout(gridLayout);
-        ICdmRepository controller = CdmStore.getCurrentApplicationConfiguration();
-        if (controller != null){
-            IPreferenceService service = controller.getPreferenceService();
-            PrefKey key = CdmPreference.NewKey(PreferenceSubject.NewDatabaseInstance(), PreferencePredicate.ShowImportExportMenu);
-            CdmPreference isShowSpecimenPref = service.find(key);
-            if (isShowSpecimenPref != null){
-                this.isShowIOMenu = Boolean.valueOf(isShowSpecimenPref.getValue());
-            }
-
-            key = CdmPreference.NewKey(PreferenceSubject.NewDatabaseInstance(), PreferencePredicate.ShowMediaView);
-            CdmPreference isShowMediaViewPref = service.find(key);
-            if (isShowMediaViewPref != null){
-                this.isShowMediaView = Boolean.valueOf(isShowMediaViewPref.getValue());
-            }
-
-            key = CdmPreference.NewKey(PreferenceSubject.NewDatabaseInstance(), PreferencePredicate.ShowChecklistPerspective);
-            CdmPreference isShowChecklistPref = service.find(key);
-            if (isShowChecklistPref != null){
-                this.isShowCheckListPerspective = Boolean.valueOf(isShowChecklistPref.getValue());
-            }
-        }
-        final Button showIOMenuButton = new Button(composite, SWT.CHECK);
-
-        showIOMenuButton.setText(Messages.DatabasePreferncesPage_Show_IOMenu);
-
-        showIOMenuButton.setSelection(isShowIOMenu);
-        showIOMenuButton.addSelectionListener(new SelectionAdapter(){
-             @Override
-             public void widgetSelected(SelectionEvent e) {
-                 isShowIOMenu = showIOMenuButton.getSelection();
 
-              }
-         });
 
-        final Button showMediaViewButton = new Button(composite, SWT.CHECK);
+    @Override
+    public boolean performOk() {
 
-        showMediaViewButton.setText(Messages.DatabasePreferncesPage_Show_MediaView);
+        if (!isApply()){
+            return true;
+        }
+       if (controller != null){
+           IPreferenceService service = controller.getPreferenceService();
+           CdmPreference pref;
+           if (isShowIOMenu == null && isAllowOverrideShowIOMenu){
+               service.remove(CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowImportExportMenu));
+           }else{
+               pref = CdmPreference.NewTaxEditorInstance(PreferencePredicate.ShowImportExportMenu, isShowIOMenu!= null? Boolean.toString(this.isShowIOMenu):null);
+               pref.setAllowOverride(isAllowOverrideShowIOMenu);
+               service.set(pref);
+           }
+
+           if(isShowCheckListPerspective == null && isAllowOverrideShowCheckListPerspective){
+               service.remove(CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowChecklistPerspective));
+           }else{
+               pref = CdmPreference.NewTaxEditorInstance(PreferencePredicate.ShowChecklistPerspective, isShowCheckListPerspective != null?Boolean.toString(this.isShowCheckListPerspective): null);
+               pref.setAllowOverride(isAllowOverrideShowCheckListPerspective);
+               service.set(pref);
+           }
 
-        showMediaViewButton.setSelection(isShowMediaView);
-        showMediaViewButton.addSelectionListener(new SelectionAdapter(){
-             @Override
-             public void widgetSelected(SelectionEvent e) {
-                 isShowMediaView = showIOMenuButton.getSelection();
 
-              }
-         });
-        final Button showChecklistPerspectiveButton = new Button(composite, SWT.CHECK);
+           PreferencesUtil.updateDBPreferences();
 
-        showChecklistPerspectiveButton.setText(Messages.DatabasePreferncesPage_Show_ChecklistPerspective);
 
-        showChecklistPerspectiveButton.setSelection(isShowCheckListPerspective);
-        showChecklistPerspectiveButton.addSelectionListener(new SelectionAdapter(){
-             @Override
-             public void widgetSelected(SelectionEvent e) {
-                 isShowCheckListPerspective = showChecklistPerspectiveButton.getSelection();
+       }
+       return true;
+   }
+    @Override
+    protected void getValues(){
+        isAdminPreference = true;
 
-              }
-         });
+        controller = CdmStore.getCurrentApplicationConfiguration();
+        if (controller != null){
+          IPreferenceService service = controller.getPreferenceService();
+          PrefKey key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowImportExportMenu);
+          CdmPreference pref = service.find(key);
+          if (pref != null){
+              isShowIOMenu = pref.getValue()!= null?Boolean.valueOf(pref.getValue()): null;
+              isAllowOverrideShowIOMenu = pref.isAllowOverride();
+          }else{
+              isShowIOMenu = null;
+              isAllowOverrideShowIOMenu = true;
+          }
+
+//          key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowMediaView);
+//          pref = service.find(key);
+//          if (pref != null){
+//              isShowMediaView = Boolean.valueOf(pref.getValue());
+//              isAllowOverrideShowMediaView = pref.isAllowOverride();
+//          }else{
+//              isShowMediaView = Boolean.valueOf(PreferencePredicate.ShowMediaView.getDefaultValue().toString());
+//              isAllowOverrideShowMediaView = true;
+//          }
+
+          key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowChecklistPerspective);
+          pref = service.find(key);
+          if (pref != null){
+              isShowCheckListPerspective = pref.getValue()!= null?Boolean.valueOf(pref.getValue()): null;
+              isAllowOverrideShowCheckListPerspective = pref.isAllowOverride();
+          }else{
+              isShowCheckListPerspective = null;
+              isAllowOverrideShowCheckListPerspective = true;
+          }
+
+          key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowTaxonNodeWizard);
+          pref = service.find(key);
+//          if (pref != null){
+//              isShowTaxonNodeWizard = pref.getValue() != null?Boolean.valueOf(pref.getValue()): null;
+//              isAllowOverrideShowTaxonNodeWizard = pref.isAllowOverride();
+//          }else{
+//              isShowTaxonNodeWizard = null;
+//              isAllowOverrideShowTaxonNodeWizard = true;
+//          }
+      }
 
-        return composite;
     }
 
     @Override
-    public void createControl(Composite parent){
-        super.createControl(parent);
-        getControl().setVisible(false);
-    }
+    protected void performDefaults() {
+        isShowIOMenu = null;
+        isShowCheckListPerspective = null;
+        //isShowTaxonNodeWizard = null;
 
-    @Override
-    public boolean performOk() {
-       ICdmRepository controller = CdmStore.getCurrentApplicationConfiguration();
-       if (controller != null){
-           IPreferenceService service = controller.getPreferenceService();
 
-           CdmPreference pref = CdmPreference.NewDatabaseInstance(PreferencePredicate.ShowImportExportMenu, Boolean.toString(this.isShowIOMenu));
-           pref.setAllowOverride(false);
-           service.set(pref);
-           pref = CdmPreference.NewDatabaseInstance(PreferencePredicate.ShowMediaView, Boolean.toString(this.isShowMediaView));
-           pref.setAllowOverride(false);
-           service.set(pref);
-           pref = CdmPreference.NewDatabaseInstance(PreferencePredicate.ShowChecklistPerspective, Boolean.toString(this.isShowCheckListPerspective));
-           pref.setAllowOverride(false);
-           service.set(pref);
-           PreferencesUtil.updateDBPreferences();
+        isAllowOverrideShowIOMenu = true;
 
 
-       }
-       return true;
-   }
+        isAllowOverrideShowCheckListPerspective = true;
+
+        //isAllowOverrideShowTaxonNodeWizard = true;
+        setSelections();
+        super.performDefaults();
+    }
 
 }