X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.modeling.ui%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Fui%2Fscl%2Fimports%2FOntologyImportModulesAction.java;fp=bundles%2Forg.simantics.modeling.ui%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Fui%2Fscl%2Fimports%2FOntologyImportModulesAction.java;h=dcf4d9d5f74183e5080e20783a2b2079601fcfd4;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.modeling.ui/src/org/simantics/modeling/ui/scl/imports/OntologyImportModulesAction.java b/bundles/org.simantics.modeling.ui/src/org/simantics/modeling/ui/scl/imports/OntologyImportModulesAction.java new file mode 100644 index 000000000..dcf4d9d5f --- /dev/null +++ b/bundles/org.simantics.modeling.ui/src/org/simantics/modeling/ui/scl/imports/OntologyImportModulesAction.java @@ -0,0 +1,42 @@ +package org.simantics.modeling.ui.scl.imports; + +import java.util.ArrayList; + +import org.eclipse.jface.dialogs.Dialog; +import org.eclipse.swt.widgets.Shell; +import org.simantics.scl.compiler.commands.CommandSessionImportEntry; +import org.simantics.scl.ui.imports.ImportModulesAction; + +public class OntologyImportModulesAction extends ImportModulesAction { + + public static final OntologyImportModulesAction INSTANCE = new OntologyImportModulesAction(); + + public OntologyImportModulesAction() { + super("Add ontology", 10.0); + } + + @Override + public boolean editImports(Shell shell, ArrayList imports) { + ModuleSelectionDialog dialog = new ModuleSelectionDialog(shell, OntologiesQuery.INSTANCE); + if(dialog.open() == Dialog.OK) { + for(Object r : dialog.getResult()) { + String uri = (String)r; + new CommandSessionImportEntry(uri, getDefaultLocalName(uri), true).addTo(imports); + } + return true; + } + else + return false; + } + + public String getDefaultLocalName(String ontologyUri) { + if(ontologyUri.contains("/Layer0-")) + return "L0"; + if(ontologyUri.contains("/Structural-")) + return "STR"; + if(ontologyUri.contains("/Modeling-")) + return "MOD"; + return ""; + } + +}