ref #6774 Implement configuration wizard page of owl term export
authorPatrick Plitzner <p.plitzner@bgbm.org>
Fri, 24 May 2019 11:46:10 +0000 (13:46 +0200)
committerPatrick Plitzner <p.plitzner@bgbm.org>
Fri, 24 May 2019 11:46:10 +0000 (13:46 +0200)
eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/io/e4/out/owl/OwlTermExportComposite.java
eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/io/e4/out/owl/OwlTermExportWizard.java
eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/io/e4/out/owl/OwlTermExportWizardPage.java

index 898e058e8bffb9d2e1bde5558fb29d7f28644c91..3b6f1008ae57d8f0b0c5eb2ad0b1f9445fc11598 100644 (file)
@@ -8,23 +8,20 @@
 */
 package eu.etaxonomy.taxeditor.io.e4.out.owl;
 
-import java.util.Collections;
-import java.util.List;
-
-import org.eclipse.jface.layout.GridLayoutFactory;
 import org.eclipse.swt.SWT;
+import org.eclipse.swt.layout.GridData;
 import org.eclipse.swt.layout.GridLayout;
+import org.eclipse.swt.widgets.Button;
 import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Text;
 
-import eu.etaxonomy.cdm.api.service.IVocabularyService;
-import eu.etaxonomy.cdm.model.term.TermType;
-import eu.etaxonomy.cdm.persistence.dto.TermDto;
-import eu.etaxonomy.cdm.persistence.dto.TermVocabularyDto;
 import eu.etaxonomy.taxeditor.editor.definedterm.DefinedTermSorter;
+import eu.etaxonomy.taxeditor.editor.definedterm.FeatureTreeViewerComparator;
 import eu.etaxonomy.taxeditor.editor.definedterm.RootElementsOnlyTreeContentProvider;
 import eu.etaxonomy.taxeditor.editor.definedterm.TermDtoLabelProvider;
+import eu.etaxonomy.taxeditor.featuretree.FeatureTreeLabelProvider;
+import eu.etaxonomy.taxeditor.model.ImageResources;
 import eu.etaxonomy.taxeditor.preference.wizard.CheckBoxTreeComposite;
-import eu.etaxonomy.taxeditor.store.CdmStore;
 
 /**
  * @author pplitzner
@@ -33,22 +30,56 @@ import eu.etaxonomy.taxeditor.store.CdmStore;
  */
 public class OwlTermExportComposite extends Composite {
 
-    private List<TermVocabularyDto> areaVocabularies;
+    private CheckBoxTreeComposite selectVocabularyComposite;
+    private CheckBoxTreeComposite selectFeatureTreeComposite;
+    private Text txtExportDirectory;
+    private Button btnSelectDirectory;
 
-    public OwlTermExportComposite(List<TermDto> selectedAreas, Composite parent, int style) {
+    public OwlTermExportComposite(Composite parent, int style) {
         super(parent, style);
-        setLayout(new GridLayout(3, false));
+        setLayout(new GridLayout(2, false));
+
+        GridData layoutData = new GridData(SWT.FILL, SWT.CENTER, true, false, 2, 1);
+        layoutData.heightHint = 200;
+        selectVocabularyComposite = new CheckBoxTreeComposite(this, new RootElementsOnlyTreeContentProvider(), new TermDtoLabelProvider(), SWT.NONE);
+        selectVocabularyComposite.setAllowTopLevelSelection(true);
+        selectVocabularyComposite.getViewer().setComparator(new DefinedTermSorter());
+        selectVocabularyComposite.setLayoutData(layoutData);
+
+        selectFeatureTreeComposite = new CheckBoxTreeComposite(this, new RootElementsOnlyTreeContentProvider(), new FeatureTreeLabelProvider(), SWT.NONE);
+        selectFeatureTreeComposite.setAllowTopLevelSelection(true);
+        selectFeatureTreeComposite.getViewer().setComparator(new FeatureTreeViewerComparator());
+        selectFeatureTreeComposite.setLayoutData(layoutData);
+
+        txtExportDirectory = new Text(this, style);
+        txtExportDirectory.setEditable(false);
+        txtExportDirectory.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
 
-        this.areaVocabularies = CdmStore.getService(IVocabularyService.class).findVocabularyDtoByTermType(TermType.NamedArea);
+        btnSelectDirectory = new Button(this, style);
+        btnSelectDirectory.setImage(ImageResources.getImage(ImageResources.BROWSE_ICON));
+        btnSelectDirectory.setToolTipText("Choose export directory");
+        btnSelectDirectory.setLayoutData(new GridData(SWT.CENTER, SWT.CENTER, false, false));
 
-        CheckBoxTreeComposite treeComposite = new CheckBoxTreeComposite(parent, new RootElementsOnlyTreeContentProvider(), new TermDtoLabelProvider(), SWT.NONE);
-        treeComposite.setAllowTopLevelSelection(true);
-        treeComposite.getViewer().setComparator(new DefinedTermSorter());
-        treeComposite.getViewer().setInput(areaVocabularies);
-        Collections.sort(selectedAreas, (o1, o2)->o1.getOrderIndex()-o2.getOrderIndex());
-        treeComposite.setCheckedElements(selectedAreas.toArray());
-        GridLayoutFactory.fillDefaults().applyTo(treeComposite);
+    }
+
+    Text getTxtExportDirectory() {
+        return txtExportDirectory;
+    }
+
+    Button getBtnSelectDirectory() {
+        return btnSelectDirectory;
+    }
+
+    CheckBoxTreeComposite getSelectFeatureTreeComposite() {
+        return selectFeatureTreeComposite;
+    }
+
+    CheckBoxTreeComposite getSelectVocabularyComposite() {
+        return selectVocabularyComposite;
+    }
 
+    String getExportDirectory(){
+        return txtExportDirectory.getText();
     }
 
 }
index d985109a0d9bee9d0b24db176529cfecf5015f59..ac6e252e2c569ff401068f5cb0901274e1ab0d7f 100644 (file)
@@ -18,6 +18,7 @@ import org.eclipse.jface.viewers.IStructuredSelection;
 
 import eu.etaxonomy.cdm.io.descriptive.owl.out.StructureTreeOwlExportConfigurator;
 import eu.etaxonomy.taxeditor.io.e4.out.AbstractExportWizardE4;
+import eu.etaxonomy.taxeditor.store.CdmStore;
 
 /**
  *
@@ -29,7 +30,7 @@ public class OwlTermExportWizard extends
 AbstractExportWizardE4<StructureTreeOwlExportConfigurator> {
 
     private StructureTreeOwlExportConfigurator configurator;
-    private OwlTermExportWizardPage owlTermExportWizardPage;
+    private OwlTermExportWizardPage exportPage;
 
     @Inject
     public OwlTermExportWizard(IEclipseContext context,
@@ -49,15 +50,17 @@ AbstractExportWizardE4<StructureTreeOwlExportConfigurator> {
 
     @Override
     public boolean performFinish() {
-//        CdmStore.getExportManager().runMoniteredOperation(configurator, urlString);
-//        PreferencesUtil.setStringValue("exportFolder", page.getFolderText());
+        configurator.setFeatureTrees(exportPage.getSelectedTrees());
+        configurator.setVocabularyUuids(exportPage.getSelectedVocabularies());
+
+        CdmStore.getExportManager().runMoniteredOperation(configurator, exportPage.getExportDirectory());
         return true;
     }
 
     @Override
     public void addPages() {
-        owlTermExportWizardPage = new OwlTermExportWizardPage("OWL term export");
-        addPage(owlTermExportWizardPage);
+        exportPage = new OwlTermExportWizardPage("OWL term export");
+        addPage(exportPage);
     }
 
 }
index 99b2d8cecf19793be35682b1c7804efcf7a1efff..f254e05b6e15d0649425404c16a5cc6b415022b8 100644 (file)
@@ -8,11 +8,25 @@
 */
 package eu.etaxonomy.taxeditor.io.e4.out.owl;
 
-import java.util.Collections;
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+import java.util.UUID;
 
 import org.eclipse.jface.wizard.WizardPage;
 import org.eclipse.swt.SWT;
+import org.eclipse.swt.events.SelectionAdapter;
+import org.eclipse.swt.events.SelectionEvent;
 import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.FileDialog;
+
+import eu.etaxonomy.cdm.api.service.IFeatureTreeService;
+import eu.etaxonomy.cdm.api.service.IVocabularyService;
+import eu.etaxonomy.cdm.model.term.FeatureTree;
+import eu.etaxonomy.cdm.model.term.TermType;
+import eu.etaxonomy.cdm.persistence.dto.TermVocabularyDto;
+import eu.etaxonomy.taxeditor.store.CdmStore;
 
 /**
  * @author pplitzner
@@ -21,6 +35,8 @@ import org.eclipse.swt.widgets.Composite;
  */
 public class OwlTermExportWizardPage extends WizardPage {
 
+    private OwlTermExportComposite composite;
+
     protected OwlTermExportWizardPage(String pageName) {
         super(pageName);
         setTitle("OWL Term Export");
@@ -29,7 +45,68 @@ public class OwlTermExportWizardPage extends WizardPage {
 
     @Override
     public void createControl(Composite parent) {
-        setControl(new OwlTermExportComposite(Collections.EMPTY_LIST, parent, SWT.NONE));
+        composite = new OwlTermExportComposite(parent, SWT.NONE);
+
+        Set<TermType> termTypes = new HashSet<>();
+        termTypes.add(TermType.Feature);
+        termTypes.add(TermType.Structure);
+        termTypes.add(TermType.Property);
+        termTypes.add(TermType.State);
+        termTypes.add(TermType.Character);
+        List<TermVocabularyDto> areaVocabularies = CdmStore.getService(IVocabularyService.class).findVocabularyDtoByTermTypes(termTypes);
+        composite.getSelectVocabularyComposite().getViewer().setInput(areaVocabularies);
+
+        List<FeatureTree> trees = CdmStore.getService(IFeatureTreeService.class).list(FeatureTree.class, null, null, null, null);
+        composite.getSelectFeatureTreeComposite().getViewer().setInput(trees);
+
+
+        composite.getBtnSelectDirectory().addSelectionListener(new SelectionAdapter() {
+            @Override
+            public void widgetSelected(SelectionEvent e) {
+                FileDialog dialog = new FileDialog(parent.getShell());
+                String[] filterNames = {
+                        "Web Ontology Language (*.owl)",
+                        "Extensible Markup Language (*.xml)",
+                        "All files (*.*)"
+                        };
+                String[] filterExtensions = { "*.owl", "*.xml", "*.*"};
+
+                dialog.setOverwrite(true);
+                dialog.setFilterNames(filterNames);
+                dialog.setFilterExtensions(filterExtensions);
+                String fileString = dialog.open();
+                if(fileString!=null){
+                    composite.getTxtExportDirectory().setText(fileString);
+                }
+            }
+        });
+        setControl(composite);
+    }
+
+    String getExportDirectory(){
+        return composite.getExportDirectory();
+    }
+
+    List<FeatureTree> getSelectedTrees(){
+        List<FeatureTree> selectedTrees = new ArrayList<>();
+        Object[] checkedElements = composite.getSelectFeatureTreeComposite().getViewer().getCheckedElements();
+        for (Object object : checkedElements) {
+            if(object instanceof FeatureTree) {
+                selectedTrees.add((FeatureTree) object);
+            }
+        }
+        return selectedTrees;
+    }
+
+    List<UUID> getSelectedVocabularies(){
+        List<UUID> vocs = new ArrayList<>();
+        Object[] checkedElements = composite.getSelectVocabularyComposite().getViewer().getCheckedElements();
+        for (Object object : checkedElements) {
+            if(object instanceof TermVocabularyDto){
+                vocs.add(((TermVocabularyDto) object).getUuid());
+            }
+        }
+        return vocs;
     }
 
 }