]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.modeling.ui/src/org/simantics/modeling/ui/handlers/e4/SyncCurrentTypicalInstanceWithTemplate.java
Migrated source code from Simantics SVN
[simantics/platform.git] / bundles / org.simantics.modeling.ui / src / org / simantics / modeling / ui / handlers / e4 / SyncCurrentTypicalInstanceWithTemplate.java
diff --git a/bundles/org.simantics.modeling.ui/src/org/simantics/modeling/ui/handlers/e4/SyncCurrentTypicalInstanceWithTemplate.java b/bundles/org.simantics.modeling.ui/src/org/simantics/modeling/ui/handlers/e4/SyncCurrentTypicalInstanceWithTemplate.java
new file mode 100644 (file)
index 0000000..86bfdc0
--- /dev/null
@@ -0,0 +1,95 @@
+package org.simantics.modeling.ui.handlers.e4;\r
+\r
+import javax.inject.Named;\r
+\r
+import org.eclipse.e4.core.di.annotations.CanExecute;\r
+import org.eclipse.e4.core.di.annotations.Execute;\r
+import org.eclipse.e4.ui.model.application.ui.basic.MPart;\r
+import org.eclipse.e4.ui.services.IServiceConstants;\r
+import org.eclipse.jface.dialogs.MessageDialog;\r
+import org.eclipse.swt.widgets.Shell;\r
+import org.eclipse.ui.IEditorPart;\r
+import org.eclipse.ui.internal.e4.compatibility.CompatibilityEditor;\r
+import org.simantics.Simantics;\r
+import org.simantics.db.Resource;\r
+import org.simantics.db.Session;\r
+import org.simantics.db.exception.DatabaseException;\r
+import org.simantics.modeling.typicals.SyncTypicalTemplatesToInstances;\r
+import org.simantics.modeling.ui.documents.OpenPlainTextDocumentAdapter;\r
+import org.simantics.modeling.ui.property.TypicalPropertyTester;\r
+import org.simantics.modeling.ui.typicals.RuleChooserDialog;\r
+import org.simantics.ui.workbench.IResourceEditorInput;\r
+import org.simantics.utils.ui.ErrorLogger;\r
+import org.simantics.utils.ui.workbench.WorkbenchUtils;\r
+\r
+/**\r
+ * @author Tuukka Lehtonen\r
+ *\r
+ */\r
+public class SyncCurrentTypicalInstanceWithTemplate {\r
+\r
+    @CanExecute\r
+    public boolean canExecute(@Named(IServiceConstants.ACTIVE_PART) MPart part) throws DatabaseException, InterruptedException {\r
+        // TODO: Fix this when we get rid of CompatibilityEditors\r
+        IEditorPart activeEditor = null;\r
+        if (part != null && part.getObject() instanceof CompatibilityEditor) {\r
+            CompatibilityEditor compEditor = (CompatibilityEditor) part.getObject();\r
+            activeEditor = compEditor.getEditor();\r
+        } else {\r
+            // TODO: This is not good practice with E4 but an OK fallback for now\r
+            activeEditor = WorkbenchUtils.getActiveEditor();\r
+        }\r
+        if (activeEditor == null)\r
+            return false;\r
+        IResourceEditorInput input = (IResourceEditorInput) activeEditor.getEditorInput();\r
+        return TypicalPropertyTester.isTypicalInstanceEditor(Simantics.getSession(), input.getResource());\r
+    }\r
+    \r
+    @Execute\r
+    public void execute(@Named(IServiceConstants.ACTIVE_SHELL) Shell shell, @Named(IServiceConstants.ACTIVE_PART) MPart mActiveEditor) {\r
+\r
+        // TODO: Fix this when we get rid of CompatibilityEditors\r
+        IEditorPart activeEditor = null;\r
+        Object editor = mActiveEditor.getObject();\r
+        if (editor instanceof CompatibilityEditor) {\r
+            CompatibilityEditor compEditor = (CompatibilityEditor) editor;\r
+            activeEditor = compEditor.getEditor();\r
+        } else {\r
+            // TODO: This is not good practice with E4 but an OK fallback for now\r
+            activeEditor = WorkbenchUtils.getActiveEditor();\r
+        }\r
+        if (activeEditor == null)\r
+            return;\r
+\r
+        IResourceEditorInput input = (IResourceEditorInput) activeEditor.getEditorInput();\r
+        Session session = Simantics.getSession();\r
+\r
+//        if (!MessageDialog\r
+//                .openConfirm(shell,\r
+//                        "Synchronize Typical Instance With Template",\r
+//                        "Are you sure you want to synchronize this typical instance with its template?"))\r
+//            return null;\r
+\r
+        try {\r
+            if (!TypicalPropertyTester.isTypicalInstanceEditor(session, input.getResource())) {\r
+                MessageDialog.openInformation(shell, "Not Synchronizing", "Currently active editor is not a typical diagram instance editor.");\r
+                return;\r
+            }\r
+\r
+            RuleChooserDialog.RuleResult result = RuleChooserDialog.choose(shell, "Synchronizing typical instance with its template.", new Resource[] { input.getResource() });\r
+            if(result == null) return;\r
+\r
+            SyncTypicalTemplatesToInstances req = SyncTypicalTemplatesToInstances.syncSingleInstance(result.selectedRules, input.getResource()).logging(result.logging); \r
+            session.syncRequest(req);\r
+            if (result.logging) {\r
+                for(Resource log : req.logs)\r
+                    new OpenPlainTextDocumentAdapter().openEditor(log);\r
+            }\r
+        } catch (Exception e) {\r
+            ErrorLogger.defaultLogError(e);\r
+        }\r
+        return;\r
+        \r
+    }\r
+\r
+}\r