Merge branch 'release/5.8.0'
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / databaseAdmin / preferencePage / GeneralAdminPreferencePage.java
index c08fcdc3753bfef7124a835e6553d8ea8f0aaf84..c5b08b2e146b83733a66f4687bdd8876d37bf9fd 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,131 +23,35 @@ 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;
-    boolean isShowTaxonNodeWizard = true;
     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);
-        controller = CdmStore.getCurrentApplicationConfiguration();
-        if (controller != null){
-            IPreferenceService service = controller.getPreferenceService();
-            PrefKey key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowImportExportMenu);
-            CdmPreference isShowSpecimenPref = service.find(key);
-            if (isShowSpecimenPref != null){
-                this.isShowIOMenu = Boolean.valueOf(isShowSpecimenPref.getValue());
-            }
-
-            key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowMediaView);
-            CdmPreference isShowMediaViewPref = service.find(key);
-            if (isShowMediaViewPref != null){
-                this.isShowMediaView = Boolean.valueOf(isShowMediaViewPref.getValue());
-            }
-
-            key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowChecklistPerspective);
-            CdmPreference isShowChecklistPref = service.find(key);
-            if (isShowChecklistPref != null){
-                this.isShowCheckListPerspective = Boolean.valueOf(isShowChecklistPref.getValue());
-            }
-
-            key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowTaxonNodeWizard);
-            CdmPreference isShowTaxonNodeWizardPref = service.find(key);
-            if (isShowTaxonNodeWizardPref != null){
-                this.isShowTaxonNodeWizard = Boolean.valueOf(isShowTaxonNodeWizardPref.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);
-
-        showMediaViewButton.setText(Messages.DatabasePreferncesPage_Show_MediaView);
-
-        showMediaViewButton.setSelection(isShowMediaView);
-        showMediaViewButton.addSelectionListener(new SelectionAdapter(){
-             @Override
-             public void widgetSelected(SelectionEvent e) {
-                 isShowMediaView = showIOMenuButton.getSelection();
-
-              }
-         });
-        final Button showChecklistPerspectiveButton = new Button(composite, SWT.CHECK);
-
-        showChecklistPerspectiveButton.setText(Messages.DatabasePreferncesPage_Show_ChecklistPerspective);
-
-        showChecklistPerspectiveButton.setSelection(isShowCheckListPerspective);
-        showChecklistPerspectiveButton.addSelectionListener(new SelectionAdapter(){
-             @Override
-             public void widgetSelected(SelectionEvent e) {
-                 isShowCheckListPerspective = showChecklistPerspectiveButton.getSelection();
-
-              }
-         });
-
-        final Button showTaxonNodeWizardButton = new Button(composite, SWT.CHECK);
-
-        showTaxonNodeWizardButton.setText(Messages.DatabasePreferncesPage_Show_TaxonNodeWizard);
-
-        showTaxonNodeWizardButton.setSelection(isShowTaxonNodeWizard);
-        showTaxonNodeWizardButton.addSelectionListener(new SelectionAdapter(){
-             @Override
-             public void widgetSelected(SelectionEvent e) {
-                 isShowTaxonNodeWizard = showTaxonNodeWizardButton.getSelection();
-
-              }
-         });
 
 
-        return composite;
-    }
-
-    @Override
-    public void createControl(Composite parent){
-        super.createControl(parent);
-        getControl().setVisible(false);
-    }
-
     @Override
     public boolean performOk() {
 
-       //ICdmRepository controller = CdmStore.getCurrentApplicationConfiguration();
+        if (!isApply()){
+            return true;
+        }
        if (controller != null){
            IPreferenceService service = controller.getPreferenceService();
 
            CdmPreference pref = CdmPreference.NewTaxEditorInstance(PreferencePredicate.ShowImportExportMenu, Boolean.toString(this.isShowIOMenu));
-           pref.setAllowOverride(true);
-           service.set(pref);
-           pref = CdmPreference.NewTaxEditorInstance(PreferencePredicate.ShowMediaView, Boolean.toString(this.isShowMediaView));
-           pref.setAllowOverride(true);
+           pref.setAllowOverride(isAllowOverrideShowIOMenu);
            service.set(pref);
+//           pref = CdmPreference.NewTaxEditorInstance(PreferencePredicate.ShowMediaView, Boolean.toString(this.isShowMediaView));
+//           pref.setAllowOverride(isAllowOverrideShowMediaView);
+//           service.set(pref);
            pref = CdmPreference.NewTaxEditorInstance(PreferencePredicate.ShowChecklistPerspective, Boolean.toString(this.isShowCheckListPerspective));
-           pref.setAllowOverride(true);
+           pref.setAllowOverride(isAllowOverrideShowCheckListPerspective);
            service.set(pref);
            pref = CdmPreference.NewTaxEditorInstance(PreferencePredicate.ShowTaxonNodeWizard, Boolean.toString(this.isShowTaxonNodeWizard));
-           pref.setAllowOverride(true);
+           pref.setAllowOverride(isAllowOverrideShowTaxonNodeWizard);
            service.set(pref);
            PreferencesUtil.updateDBPreferences();
 
@@ -164,5 +59,86 @@ public class GeneralAdminPreferencePage extends CdmPreferencePage implements IE4
        }
        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 = Boolean.valueOf(pref.getValue());
+              isAllowOverrideShowIOMenu = pref.isAllowOverride();
+          }else{
+              isShowIOMenu = Boolean.valueOf(PreferencePredicate.ShowImportExportMenu.getDefaultValue().toString());
+              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 = Boolean.valueOf(pref.getValue());
+              isAllowOverrideShowCheckListPerspective = pref.isAllowOverride();
+          }else{
+              isShowCheckListPerspective = Boolean.valueOf(PreferencePredicate.ShowChecklistPerspective.getDefaultValue().toString());
+              isAllowOverrideShowCheckListPerspective = true;
+          }
+
+          key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowTaxonNodeWizard);
+          pref = service.find(key);
+          if (pref != null){
+              isShowTaxonNodeWizard = Boolean.valueOf(pref.getValue());
+              isAllowOverrideShowTaxonNodeWizard = pref.isAllowOverride();
+          }else{
+              isShowTaxonNodeWizard = Boolean.valueOf(PreferencePredicate.ShowTaxonNodeWizard.getDefaultValue().toString());
+              isAllowOverrideShowTaxonNodeWizard = true;
+          }
+      }
+
+    }
+
+    @Override
+    protected void performDefaults() {
+        isShowIOMenu = Boolean.valueOf(PreferencePredicate.ShowImportExportMenu.getDefaultValue().toString());
+        if (isShowIOMenu){
+            showIOMenuButton.select(0);
+        }else{
+            showIOMenuButton.select(1);
+        }
+        isShowCheckListPerspective = Boolean.valueOf(PreferencePredicate.ShowChecklistPerspective.getDefaultValue().toString());
+        if (isShowCheckListPerspective){
+            showChecklistPerspectiveButton.select(0);
+        }else{
+            showChecklistPerspectiveButton.select(1);
+        }
+
+        isShowTaxonNodeWizard = Boolean.valueOf(PreferencePredicate.ShowTaxonNodeWizard.getDefaultValue().toString());
+        if (isShowTaxonNodeWizard){
+            showTaxonNodeWizardButton.select(0);
+        }else{
+            showTaxonNodeWizardButton.select(1);
+        }
+
+        isAllowOverrideShowIOMenu = true;
+
+        allowOverrideShowIOMenuButton.setSelection(isAllowOverrideShowIOMenu);
+        isAllowOverrideShowCheckListPerspective = true;
+        allowOverrideShowChecklistButton.setSelection(isAllowOverrideShowCheckListPerspective);
+        isAllowOverrideShowTaxonNodeWizard = true;
+        allowOverrideShowTaxonNodeWizardButton.setSelection(isAllowOverrideShowTaxonNodeWizard);
+        super.performDefaults();
+    }
 
 }